Python Subprocess模块原理及实例
前言
其实有一个模块也支持执行系统命令,那个模块就是sys.system,但他执行系统命令会直接通过主进程去执行命令,那假如,该命令的执行需要耗费一个小时,那么主进程会卡一个小时,而不会去干别的事,这样就会导致程序的运行效率低下。
如果由subprocess去执行系统命令的时候并不会让主进程去执行,而是主进程会开辟出一个子进程去执行,并不会影响到主进程的运行,主进程该干嘛就干嘛,那么又有个问题,大家都知道进程之间的内存空间是独立的,也就是说进程之间是不能相互访问的,那么在subprocess中,有个管道的概念,既然固定死了进程之间不能相互访问,那么可以将执行命令的结果输出到管道里,该管道其实就是一块共享的内存空间,可以让主进程去获取到该共享内存空间存放的数据
subprocess基本工作原理

subprocess简单案例
import subprocess
# 创建一个子进程去执行系统命令
obj=subprocess.Popen(
'ps -ef', # 执行的系统命令(必须是字符串格式)
shell=True, # 指定命令解释器来解释执行的这条命令
stdout=subprocess.PIPE, # 将执行的正确结果丢到管道(共享内存空间,用于进程之间共享)
stderr=subprocess.PIPE # 将执行的错误结果丢到另一个新的管道
)
'''
当从任意一个管道,例如正确或者错误结果管道中获取值,
'''
# 从正确管道中获取值
res=obj.stdout.read() # 主进程去管道里获取正确的结果
print(res.decode('utf-8')) # 获取的结果是bytes类型,需要指定decode指定编码
# 从错误管道中获取值
res2=obj.stderr.read()
print(res2.decode('utf-8'))
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
Pandas Groupby之在Python中汇总、聚合和分组数据的示例详解
GroupBy是一个非常简单的概念,我们可以创建一个类别分组,并对这些类别应用一个函数,本文给大家介绍Pandas Groupby之如何在Python中汇总、聚合和分组数据,感兴趣的朋友跟随小编一起看看吧2023-07-07
python条件判断中not、is、is not、is not None、is None代码实例
None是python中的一个特殊的常量,表示一个空的对象,下面这篇文章主要给大家介绍了关于python条件判断中not、is、is not、is not None、is None的相关资料,需要的朋友可以参考下2024-03-03
一个基于flask的web应用诞生 使用模板引擎和表单插件(2)
一个基于flask的web应用诞生第二篇,这篇文章主要介绍了如何使用jinja2模板引擎和wtf表单插件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2017-04-04
Python设计模式中单例模式的实现及在Tornado中的应用
这篇文章主要介绍了Python设计模式中单例模式的实现及在Tornado中的应用,讲解了单例模式用于设计Tornado框架中的线程控制方面的相关问题,需要的朋友可以参考下2016-03-03
使用Python爬虫库requests发送表单数据和JSON数据
今天再为大家介绍下使用Python爬虫库requests发送表单数据和JSON数据的方法,这是最基本的使用方法,大家可以参考测试下2020-01-01


最新评论