python中subprocess批量执行linux命令


Posted in Python onApril 27, 2018

可以执行shell命令的相关模块和函数有:

  • os.system
  • os.spawn
  • os.popen --废弃
  • popen --废弃
  • commands --废弃,3.x中被移除

以上执行shell命令的相关的模块和函数的功能均在 subprocess 模块中实现,并提供了更丰富的功能。

subprocess

call

执行命令,返回状态码

>>> import subprocess
>>> ret = subprocess.call(["ls", "-l"], shell=False)
total 4684
-rw-r--r-- 1 root root   454 May 5 12:20 aa.py
-rw-r--r-- 1 root root    0 May 8 16:51 aa.txt
-rw-r--r-- 1 root root 4783286 Apr 11 16:39 DockerToolbox.exe
-rw-r--r-- 1 root root   422 May 5 12:20 ip_info.txt
-rw-r--r-- 1 root root   718 Apr 19 10:52 my.cnf
>>> ret = subprocess.call("ls -l", shell=True)
total 4684
-rw-r--r-- 1 root root   454 May 5 12:20 aa.py
-rw-r--r-- 1 root root    0 May 8 16:51 aa.txt
-rw-r--r-- 1 root root 4783286 Apr 11 16:39 DockerToolbox.exe
-rw-r--r-- 1 root root   422 May 5 12:20 ip_info.txt
-rw-r--r-- 1 root root   718 Apr 19 10:52 my.cnf
>>> print(ret)
0

check_call

执行命令,如果执行状态码是 0 ,则返回0,否则抛异常

>>> subprocess.check_call(["ls", "-l"])
total 4684
-rw-r--r-- 1 root root   454 May 5 12:20 aa.py
-rw-r--r-- 1 root root    0 May 8 16:51 aa.txt
-rw-r--r-- 1 root root 4783286 Apr 11 16:39 DockerToolbox.exe
-rw-r--r-- 1 root root   422 May 5 12:20 ip_info.txt
-rw-r--r-- 1 root root   718 Apr 19 10:52 my.cnf
0
>>> subprocess.check_call("exit 1", shell=True)
Traceback (most recent call last):
 File "<stdin>", line 1, in <module>
 File "/usr/local/python3.5/lib/python3.5/subprocess.py", line 581, in check_call
  raise CalledProcessError(retcode, cmd)
subprocess.CalledProcessError: Command 'exit 1' returned non-zero exit status 1

check_output

执行命令,如果状态码是 0 ,则返回执行结果,否则抛异常

>>> subprocess.check_output(["echo", "Hello World!"])
b'Hello World!\n'
>>> subprocess.check_output("exit 1", shell=True)
Traceback (most recent call last):
 File "<stdin>", line 1, in <module>
 File "/usr/local/python3.5/lib/python3.5/subprocess.py", line 626, in check_output
  **kwargs).stdout
 File "/usr/local/python3.5/lib/python3.5/subprocess.py", line 708, in run
  output=stdout, stderr=stderr)
subprocess.CalledProcessError: Command 'exit 1' returned non-zero exit status 1

subprocess.Popen(...)

用于执行复杂的系统命令

参数:

args:shell命令,可以是字符串或者序列类型(如:list,元组)

bufsize:指定缓冲。0 无缓冲,1 行缓冲,其他 缓冲区大小,负值 系统缓冲

stdin, stdout, stderr:分别表示程序的标准输入、输出、错误句柄

preexec_fn:只在Unix平台下有效,用于指定一个可执行对象(callable object),它将在子进程运行之前被调用

close_sfs:在windows平台下,如果close_fds被设置为True,则新创建的子进程将不会继承父进程的输入、输出、错误管道。

所以不能将close_fds设置为True同时重定向子进程的标准输入、输出与错误(stdin, stdout, stderr)。

shell:同上

cwd:用于设置子进程的当前目录

env:用于指定子进程的环境变量。如果env = None,子进程的环境变量将从父进程中继承。

universal_newlines:不同系统的换行符不同,True -> 同意使用 n

startupinfo与createionflags只在windows下有效

将被传递给底层的CreateProcess()函数,用于设置子进程的一些属性,如:主窗口的外观,进程的优先级等等

执行普通命令

>>> import subprocess
>>> ret1 = subprocess.Popen(["mkdir","t1"])
>>> ret2 = subprocess.Popen("mkdir t2", shell=True)
>>> print(ret1)
<subprocess.Popen object at 0x7f4d7609dd30>
>>> print(ret2)
<subprocess.Popen object at 0x7f4d7609dc18>

终端输入的命令分为两种:

  • 输入即可得到输出,如:ifconfig
  • 输入进行某环境,依赖再输入,如:python
>>> import subprocess
>>> obj = subprocess.Popen("mkdir t3", shell=True, cwd='/tmp/',)
>>> import subprocess
>>> obj = subprocess.Popen(["python"], stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.PIPE, universal_newlines=True)
>>> obj.stdin.write("print(1)\n")
9
>>> obj.stdin.write("print(2)")
8
>>> obj.stdin.close()
>>> cmd_out = obj.stdout.read()
>>> obj.stdout.close()
>>> cmd_error = obj.stderr.read()
>>> obj.stderr.close()
>>> print(cmd_out)
1
2
>>> print(cmd_error)
>>> import subprocess
>>> 
>>> obj = subprocess.Popen(["python"], stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.PIPE, universal_newlines=True)
>>> obj.stdin.write("print(1)\n")
9
>>> obj.stdin.write("print(2)")
8
>>> 
>>> out_error_list = obj.communicate()
>>> print(out_error_list)
('1\n2\n', '')
>>> obj = subprocess.Popen(["python"], stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.PIPE, universal_newlines=True)
>>> out_error_list = obj.communicate('print("hello")')
>>> print(out_error_list)
('hello\n', '')
Python 相关文章推荐
Python实现检测服务器是否可以ping通的2种方法
Jan 01 Python
78行Python代码实现现微信撤回消息功能
Jul 26 Python
Tornado Web Server框架编写简易Python服务器
Jul 28 Python
Python数据结构之栈、队列及二叉树定义与用法浅析
Dec 27 Python
浅谈python requests 的put, post 请求参数的问题
Jan 02 Python
详解Python数据分析--Pandas知识点
Mar 23 Python
Python爬虫 scrapy框架爬取某招聘网存入mongodb解析
Jul 31 Python
python开头的coding设置方法
Aug 08 Python
Django框架 querySet功能解析
Sep 04 Python
python matplotlib如何给图中的点加标签
Nov 14 Python
jupyter notebook 增加kernel教程
Apr 10 Python
python基于爬虫+django,打造个性化API接口
Jan 21 Python
python复制文件到指定目录的实例
Apr 27 #Python
Python多进程multiprocessing.Pool类详解
Apr 27 #Python
python获取程序执行文件路径的方法(推荐)
Apr 26 #Python
python中的文件打开与关闭操作命令介绍
Apr 26 #Python
python3获取当前文件的上一级目录实例
Apr 26 #Python
详谈Python3 操作系统与路径 模块(os / os.path / pathlib)
Apr 26 #Python
python3中获取文件当前绝对路径的两种方法
Apr 26 #Python
You might like
Thinkphp模板标签if和eq的区别和比较实例分析
2015/07/01 PHP
PHP类的声明与实例化及构造方法与析构方法详解
2016/01/26 PHP
php中序列化与反序列化详解
2017/02/13 PHP
php数值转换时间及时间转换数值用法示例
2017/05/18 PHP
JavaScript Konami Code 实现代码
2009/07/29 Javascript
jQuery文本框(input textare)事件绑定方法教程
2013/04/24 Javascript
详解JS函数重载
2014/12/04 Javascript
JavaScript实现的双向跨域插件分享
2015/01/31 Javascript
Jquery attr()方法 属性赋值和属性获取详解
2016/04/15 Javascript
jQuery动态添加可拖动元素完整实例(附demo源码下载)
2016/06/21 Javascript
学习掌握JavaScript中this的使用技巧
2016/08/29 Javascript
jquery删除table当前行的实例代码
2016/10/07 Javascript
jQuery Easyui datagrid连续发送两次请求问题
2016/12/13 Javascript
用jQuery.ajaxSetup实现对请求和响应数据的过滤
2016/12/20 Javascript
Javascript的this用法
2017/01/16 Javascript
vue.js中指令Directives详解
2017/03/20 Javascript
详解Axios 如何取消已发送的请求
2018/10/20 Javascript
详解基于node.js的脚手架工具开发经历
2019/01/28 Javascript
vue中使用[provide/inject]实现页面reload的方法
2019/09/30 Javascript
基于javascript处理二进制图片流过程详解
2020/06/08 Javascript
javascript实现点击产生随机图形
2021/01/25 Javascript
Python二维码生成库qrcode安装和使用示例
2014/12/16 Python
Python遍历zip文件输出名称时出现乱码问题的解决方法
2015/04/08 Python
python基于右递归解决八皇后问题的方法
2015/05/25 Python
wxpython绘制音频效果
2019/11/18 Python
Django 自定义权限管理系统详解(通过中间件认证)
2020/03/11 Python
Python xlwings插入Excel图片的实现方法
2021/02/26 Python
英国时尚高尔夫服装购物网站:Trendy Golf
2020/01/10 全球购物
一道SQL面试题
2012/12/31 面试题
成品仓管员工作职责
2013/12/29 职场文书
英文商务邀请信
2014/01/22 职场文书
适用于所有创业者的创业计划书
2014/02/05 职场文书
2014年惩防体系建设工作总结
2014/12/01 职场文书
党小组评议意见
2015/06/02 职场文书
安全生产奖惩制度
2015/08/06 职场文书
golang日志包logger的用法详解
2021/05/05 Golang