python执行linux
摘要: Linux , Python
工作中需要频繁使用到一个字符串的md5,因此编写一个md5命令工具,输入字符串直接得到输出,并且命令支持参数设置,比如是否事先格式化,指定不同参数可以支持多功能输出,操作步骤如下
直接vim一个脚本,脚本名md5不需要.py后缀,这样更像一个命令,注意在脚本第一行引入python解释器,并设置utf-8编码
其中-f支持先格式化再得到md5,-l支持传入多个字符串用空格分开
赋予可执行权限
测试是否符合要求
直接放置到 /usr/local/bin 目录下(需要root权限)
也可以使用软连接的方式,推荐使用绝对路径
之后就可以在环境变量中直接使用到md5命令
shebang :中文翻译“释伴”,由 #! 开头的字符串,出现在文本文件的 第一行 。类UNIX操作系统的程序载入器会分析shebang后的内容,将这些内容作为解释命令,并调用该指令,并将载有 shebang的文件路径作为该解释器 的参数
比如 #!/bin/bash 就是使用/bin/bash作为解释器运行脚本,如果以Python作为解释器运行脚本先找到Python解释器的路径,一般在Linux自带的 /usr/bin/python 是Python2版本,也可以指定其他Python版本 #!/opt/anaconda3/bin/python ,第二行为 # coding=utf-8 用来指定编码格式,否则Python2输出中文乱码
对于自定义脚本,推荐放置在 /usr/local/bin 目录,有多个可执行文件目录在环境变量中,区别如下:
/bin : 包含二进制可执行文件,为系统最基本的命令,如ls等
/sbin : 与/bin 类似,不同之处是其为root权限命令文件
/usr/bin : 系统预装可执行文件,会随着系统升级而改变
/usr/sbin : 同上,不同之处是其为root权限运用
/usr/local/bin : 三级目录,用户自己的可执行文件,系统不管理
/usr/local/sbin : root权限用户程序
B. Python脚本在Linux上怎么运行
一种方式是用Python命令加Python脚本文件名来运行,如果是运行Python 2.x的Python脚本,可以用python命令(字母P小写)执行:python 文件名;如果是运行Python 3.x的Python脚本,就用python3命令行执行:python3 文件名。
还有一个直接输入脚本文件名来运行Python脚本的方式,不过这个Python脚本必须具有可执行权限(Linux系统中有执行权限的文件才可以执行,即便是一个二进制文件没有可执行权限也是不能运行的),给一个文件添加可执行权限的命令是:chmod a+x 文件路径。注意一点:输入的脚本文件名如果不是一个绝对路径的文件名,就要先用cd命令切换到脚本所在文件夹,然后以./文件名的方式运行(文件名前面加的是一个英文点号和一个英文斜杠,表示在当前目录下运行文件),./必须加上。
C. python放在linux哪个目录下可直接执行
usr/bin下。python的可执行文件的目录一般在/usr/bin下,通过apt-get安装的应用一般会在这个目录直接运行0。Python由荷兰数学和计算机科学研究学会的GuidovanRossum于1990年代初设计,作为一门叫做ABC语言的替代品。Linux是一种自由和开放源代码的类UNIX操作系统。
D. Linux后台运行Python程序
第一种nohup命令来让程序在后台运行
括号内容表示可以将平时输出到控制台中的内容重定向到*.log这个文件中,这个是可选的,如果没有这个,则会默认输出到nohup.out文件中。括号后面你的&表示后台运行。
举个例子:
第二种方法是写一个脚本,假设我们定义了一个脚本run.sh
#!/bin/bash 是指此脚本使用/bin/bash来解释执行下面的语句,其中cd是表示将当前目录跳到所要运行文件所在目录,然后python3 文件名.py则表示运行***python文件,当写完该脚本后,执行以下命令来执行该脚本从而让程序在后台运行。
通过 ps -ef|grep python3 命令可以查看后台运行的进程都有哪些
E. Python脚本在Linux上怎么运行
linux有下列的几种方法来运行python脚本:(注:我所用的python环境为2.6)一.终端命令行下[]$python"name.py"二.python环境中若脚本名称为name.py,其内容为:a='head'b='hehe'print(a,b)则使用>>>impportname针对此种方法我们使用下面的语句来显示内容:>>>print(name.a)>>>head>>>print(name.b)>>>hehe在同一个python环境中,第一次import加载以后,以后再使用import就不会有相应的结果显示了,在这个时候可以使用>>>reload(name)在python3.0中可能要加载ipm模块才能使用reload()函数>>>fromimpimportreload>>>reload(name)三.使用from假设脚本的名称为name.pyname.py的内容为:a='head'b='hehe'print(a,b)可以使用下边的方法来运行脚本:>>>fromnameimporta,b,c在这个python环境中我们就可以使用简单的变量名来调用其内容了。eg:>>>a>>>'head'>>>b>>>'hehe'四.使用exec方法为:>>>exec(open('name.py').read())NOTICE:在上面的方法中,第三种和第四种方法会默认覆盖python环境中已经存在的且和name.py中有重名的变量名,且系统不会给出提示,请注意这一点!!!
F. linux python运行报编码错误
一次重启服务器后,supervisor接管的python脚本中的函数 open() 和 print() 都会报下面的编码错误:
UnicodeEncodeError: 'ascii' codec can't encode
使用的是python3,按理说编码都会默认utf-8,而且本地运行的python脚本并没有这个问题。
经大佬指点,增加环境变量 export LC_ALL="en_US.UTF-8" 后,再重启supervisor,问题解决
下面是复制的: https://www.cnblogs.com/badboy200800/p/11215981.html
Locale是一个软件在运行时的语言环境,。是根据计算机用户所使用的语言,所在国家或者地区,以及当地的文化传统所定义的。它包括语言(Language), 地域 (Territory) 和字符集(Codeset)。
一个locale的书写格式为: 语言[ 地域[.字符集]]。完全的locale表达方式是 [语言[ 地域][.字符集] [@修正值]。例如:
zh_CN.GB2312 => 中文_中华人民共和国+国标2312字符集。
(1)locale把按照所涉及到的文化传统的各个方面分成12个大类
(2)查看标准字符集列表
常用字符集:en_US.utf8、zh_CN.gb2312、zh_CN.gbk、zh_CN.utf8等
3.Locale的设定
LC_ALL和LANG优先级的关系:LC_ALL > LC_* >LANG
(1)如果需要一个纯中文的系统的话,设定LC_ALL= zh_CN.XXXX即可。或者设定LANG=zh_CN.XXXX也可以,但是LC_ 不要有任何特殊设定才可以(因为LC_ 优先级高)。
(2)如果需要个性化的环境,例如只想要一个可以输入中文的环境,而保持菜单、标题,系统信息等等为英文界面,那么只需要设定LANG=en_US.XXXX,然后 LC_CTYPE=zh_CN.XXXX就可以了。
(3)假如什么也不做的话,也就是LC_ALL,LANG和LC_*均不指定特定值的话,系统将采用POSIX作为lcoale,也就是C locale。
4.查看与设定字符集实践
(1)查看当前系统字符集三种方式(LC_ALL、LC_CTYPE和LANG),以查看LANG为例:
(2)更改系统字符集
备注:直接执行上述命令,可以临时修改系统字符集。如果写入环境变量可以永久改变字符集。
(3)取消当前系统字符集(设定为空)
备注:直接执行上述命令,可以临时修改系统字符集。如果写入环境变量可以永久改变字符集。
G. 在Python中调用linux命令
目的:用Python做出全自动化的pipline,用于rrbs
最近有个需求就是页面上执行shell命令,第一想到的就是os.system,
os.system('cat /proc/cpuinfo')
但是发现页面上打印的命令执行结果 0或者1,当然不满足需求了。
尝试第二种方案 os.popen()
output = os.popen('cat /proc/cpuinfo')printoutput.read()
通过 os.popen() 返回的是 file read 的对象,对其进行读取 read() 的操作可以看到执行的输出。但是无法读取程序执行的返回值)
尝试第三种方案 commands.getstatusoutput() 一个方法就可以获得到返回值和输出,非常好用。
(status, output) = commands.getstatusoutput('cat /proc/cpuinfo')printstatus, output
Python Document 中给的一个例子,
>>>import commands>>> commands.getstatusoutput('ls /bin/ls')
(0, '/bin/ls')>>> commands.getstatusoutput('cat /bin/junk')
(256,'cat: /bin/junk: No such file or directory')>>> commands.getstatusoutput('/bin/junk')
(256,'sh: /bin/junk: not found')>>> commands.getoutput('ls /bin/ls')'/bin/ls'>>> commands.getstatus('/bin/ls')'-rwxr-xr-x 1 root 13352 Oct 14 1994 /bin/ls'
最后页面上还可以根据返回值来显示命令执行结果。
H. 怎么在linux上运行python
Linux默认是已经安装好了Python程序
目前来说,大多数的Linux发行版是安装了两个版本的Python程序
一个是Python 2.x
一个是Python 3.x
一些系统自带的程序文件需要Python 2的支持,另外Python 3又是大势所趋
所以,我们最好不要动系统的Python版本
需要使用哪个版本直接声明就可以了
运行Python的方法:
我们在Linux系统上打开终端
输入python
会弹出Python 2的版本和解释器
输入python3
会弹出Python 3的版本和解释器
所以我们一般情况下,运行python 2的程序就输入命令
python 程序文件
运行python 3的程序输入命令
python3 程序文件
这里我们默认使用版本为Python 3
在终端输入命令
Python3
弹出Python的解释器以>>>开头
我们可以在上面输入Python程序
它会直接输出结果
比如:
我们这里输入32+46,输出结果为78
输入print('hello python'),输出结果hello python
注意:当我们运行.py文件时,文件里的32+46是不会直接打印出来的
必须加打印命令
print(32+46)
我们退出python3解释器的快捷键不是Ctrl+C
而是Ctrl+Z
更多Python相关技术文章,请访问Python教程栏目进行学习!以上就是小编分享的关于怎么在linux上运行python的详细内容希望对大家有所帮助,更多有关python教程请关注环球青藤其它相关文章!
I. 将Python程序打包成linux可执行文件
1.安装环境
首先我们要安装pip,命令如下:
使用的工具是 pyinstaller ,打开终端输入sudo pip install pyinstaller
2.打包程序
首先在打包之前检查一下我们的py文件是否可以正常执行,确认无误后进行打包 pyinstaller -F car_tkinter.py 或者 python3 -m PyInstaller -F main.py
3.执行文件
进入我们打包存放的文件夹,打开终端,执行语句 ./car_tkinter 或者 nohup ./car_tkinter> data.log &
J. Python脚本在Linux上怎么运行
一、首先下载安装python,建议安装2.7版本以上,3.0版本以下,由于3.0版本以上不向下兼容,体验较差。