linux执行python脚本

发布网友 发布时间:2022-04-24 08:59

我来回答

2个回答

懂视网 时间:2022-05-10 09:52

Python 3的更新已经有一段时间了,相比较于Python2也有许多不同的改变,Python 3 在Linux中也是利用比较多的,这里主要实践了一些Python3利用Linux的脚本执行命令。

首先,如果只需要执行,或者只需要得到执行的状态可以用 os.system 调用

#!/usr/bin/env python3
print ('hello,world')
import os
val2 = os.system('cd trb && cd trb')
val3 = os.system('ls')
print('val2 is ',val2)

上述代码。如果val2内代码执行成功,即有两级trb文件夹,则val2 的值是0 否则是256

两行调用没有继承性,如果要连续执行就在一个语句里加 && (Shell 语法)

在print之前,屏幕还会显示执行的结果

hello,worldsh: line 0: cd: trb: 没有那个文件或目录
Abcd.py automesh.sh Cal_Ori fold.txt Linux_py_temp.py meshedjob.rec new_geom onc143314 trb
val2 is 256

os.popen(cmd)方法,只能得到运行的输出,但是如果不print屏幕上就什么也没有。

例如

val4 = os.popen('cd trb && cd trb')
val5 = os.popen('ls')print('开始PRINT')print(val4.read())print(val5.read())

显示如下

hello,world
开始PRINT/bin/sh: line 0: cd: trb: 没有那个文件或目录
Abcd.py
automesh.shCal_Ori
fold.txt
Linux_py_temp.py
meshedjob.rec
new_geom
onc143314
trb

这里输出是类文件的对象,要调用read或者readlines读取也可以用来遍历。

############

终极武器,subprocess

py3.5后建议使用的模块subprocess

网上教程里的commands 是2里的功能,在3里被删除,但是可以通过subprocess调用

有以下命令:

subprocess.getstatusoutputcmd

在shell中返回执行cmd(status, output) 返回2个元素的元组

3.4之后添加win支持

subprocess.getoutputcmd

执行cmd然后返回结果

legacycmd = subprocess.getstatusoutput('ls -l')print('subprocess.getstatusoutput 
输出',legacycmd) legacycmd2 = subprocess.getoutput('ls -l')print('subprocess.getoutput 输出',legacycmd2)

上面为代码

输出:

subprocess.getstatusoutput 
输出 (0, '总用量 48 -rwxr--r-- 1 para036 bjpara 516 4月 16 2018 Abcd.py -rwxr--r-- 1 para036 bjpara 1619 4月 16 16:58 automesh_onpsn_fortest.sh -rwxr--r-- 1 para036 bjpara 1616 4月 15 14:31 automesh.sh drwxr-xr-x 5 para036 bjpara 4096 4月 15 14:31 Cal_Ori -rw-r --r-- 1 para036 bjpara 32 4月 16 16:56 fold.txt -rwxr--r-- 1 para036 bjpara 1530 4月 15 14:45 Linux_py_temp.py -rw-r--r-- 1 para036 bjpara 27 4月 15 14:43 meshedjob.rec drwxr-xr-x 2 para036 bjpara 4096 4月 15 14:31 new_geom drwxr-xr-x 5 para036 bjpara 4096 4月 15 14:51 onc143314 drwx r-xr-x 5 para036 bjpara 4096 4月 16 17:05 onc16165650 drwxr-xr-x 5 para036 bjpara 4096 4月 16 16:46 onc163840 drwxr-xr-x 2 para036 bjpara 4096 4 月 15 14:32 trb') subprocess.getoutput 输出 总用量 48 -rwxr--r-- 1 para036 bjpara 516 4月 16 2018 Abcd.py -rwxr--r-- 1 para036 bjpara 1619 4月 16 16:58 automesh_onpsn_fortest.sh -rwxr--r-- 1 para036 bjpara 1616 4月 15 14:31 automesh.sh drwxr-xr-x 5 para036 bjpara 4096 4月 15 14:31 Cal_Ori -rw-r--r-- 1 para036 bjpara 32 4月 16 16:56 fold.txt -rwxr--r-- 1 para036 bjpara 1530 4月 15 14:45 Linux_py_temp.py -rw-r--r-- 1 para036 bjpara 27 4月 15 14:43 meshedjob.rec drwxr-xr-x 2 para036 bjpara 4096 4月 15 14:31 new_geom drwxr-xr-x 5 para036 bjpara 4096 4月 15 14:51 onc143314 drwxr-xr-x 5 para036 bjpara 4096 4月 16 17:05 onc16165650 drwxr-xr-x 5 para036 bjpara 4096 4月 16 16:46 onc163840 drwxr-xr-x 2 para036 bjpara 4096 4月 15 14:32 trb

  其中output是字符串。如果不print就不显示

新的版本推荐使用subprocess.run() 来解决一般问题。

subprocess.run()、subprocess.call()、subprocess.check_call()和subprocess.check_output()都是通过对subprocess.Popen的封装来实现的高级函数,因此如果我们需要更复杂功能时,可以通过subprocess.Popen来完成

run默认不会返回输出,只返回命令和执行状态

recomd = subprocess.run(['ls','-l'])#等待命令执行完成后会在屏幕
输出执行结果,然后返回一个包含执行结果的CompletedProcess类的实例。print('输出recmd ',recomd)print(recomd.returncode)

输出如下:

如果要返回输出,要添加参数,传递subprocess.PIPE给stdout和stderr,然后可以通过返回的CompletedProcess类实例的stdout和stderr属性或捕获相应的内容;

universal_newlines: 该参数影响的是输入与输出的数据格式,比如它的值默认为False,此时stdout和stderr的输出是字节序列;当该参数的值设置为True时,stdout和stderr的输出是字符串。

总代码如下:

#!/usr/bin/env python3
print ('hello,world')
import os
# val2 = os.system('cd trb && cd trb')
# val3 = os.system('ls')
# print('val2 is ',val2)
# val4 = os.popen('cd trb && cd trb')
# val5 = os.popen('ls')
# print('开始PRINT')
# print(val4.read())
# print(val5.read())
import subprocess
recomd = subprocess.run(['ls','-l'])
#等待命令执行完成后会在屏幕
输出执行结果,然后返回一个包含执行结果的CompletedProcess类的实例。 print('输出recmd ',recomd) print(recomd.returncode) print('传递参数') recomdouterr = subprocess.run( ['ls','-l'],stdout=subprocess.PIPE,stderr=subprocess.PIPE,universal_newlines=True) print('输出outerr',recomdouterr.stdout,recomdouterr.stderr) print('传递参数2') recomdouterr = subprocess.run( ['ls','-l'],stdout=subprocess.PIPE,universal_newlines=True) print('输出outerr',recomdouterr.stdout) print(len( recomdouterr.stdout.strip().split(' ') )) print(recomdouterr.stdout.strip().split(' ')[-1]) # legacycmd = subprocess.getstatusoutput('ls -l') # # print('subprocess.getstatusoutput 输出',legacycmd) # # legacycmd2 = subprocess.getoutput('ls -l') # # print('subprocess.getoutput 输出',legacycmd2)

参考资料:python3.5 官方文档 : https://docs.python.org/3.5/library/subprocess.html

Python的使用途径越来越广泛了,而Linux作为服务器端也是大有作为,使用Python来实现Linux的脚本操作,简化了服务器端的操作,提高了可控性。

热心网友 时间:2022-05-10 07:00

linux执行python脚本需要分五步进行,下面是具体介绍:
1、输入cat/proc/version,查看Linux内核版本号、gcc编译器版本号和Ubuntu版本号;

2、输入python3--version查看安装的python3版本号;

3、输入vifirst.py,新建一个较first.py的脚本;

4、输入vifirst.py后按回车,然后按Insert键,然后编辑该脚本,输入如下代码:
print(“helloworld”)。
然后按Esc键,然后输入:(冒号),然后输入wq按回车保存退出;

5、输入pythonfirst.py运行该脚本,屏幕便会显示helloworld;

6、输入ls按回车,即可看到当前路径下有这个first.py脚本。

以上就是小编今天的分享了,希望可以帮助到大家。

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com