前言
其實(shí)有一個(gè)模塊也支持執(zhí)行系統(tǒng)命令,那個(gè)模塊就是sys.system
,但他執(zhí)行系統(tǒng)命令會(huì)直接通過主進(jìn)程去執(zhí)行命令,那假如,該命令的執(zhí)行需要耗費(fèi)一個(gè)小時(shí),那么主進(jìn)程會(huì)
卡一個(gè)小時(shí),而不會(huì)去干別的事,這樣就會(huì)導(dǎo)致程序的運(yùn)行效率低下。
成都創(chuàng)新互聯(lián)始終堅(jiān)持【策劃先行,效果至上】的經(jīng)營(yíng)理念,通過多達(dá)十多年累計(jì)超上千家客戶的網(wǎng)站建設(shè)總結(jié)了一套系統(tǒng)有效的全網(wǎng)營(yíng)銷解決方案,現(xiàn)已廣泛運(yùn)用于各行各業(yè)的客戶,其中包括:成都展覽展示等企業(yè),備受客戶贊許。
如果由subprocess
去執(zhí)行系統(tǒng)命令
的時(shí)候并不會(huì)讓主進(jìn)程去執(zhí)行,而是主進(jìn)程會(huì)開辟出一個(gè)子進(jìn)程
去執(zhí)行,并不會(huì)影響到主進(jìn)程
的運(yùn)行,主進(jìn)程
該干嘛就干嘛,那么又有個(gè)問題,大家都知道進(jìn)程之間的內(nèi)存空間是獨(dú)立
的,也就是說進(jìn)程之間
是不能相互訪問
的,那么在subprocess
中,有個(gè)管道的概念,既然固定死了進(jìn)程之間不能相互訪問
,那么可以將執(zhí)行命令的結(jié)果輸出到管道里,該管道其實(shí)就是一塊共享的內(nèi)存空間
,可以讓主進(jìn)程
去獲取到該共享內(nèi)存空間存放的數(shù)據(jù)
subprocess基本工作原理:
subprocess簡(jiǎn)單案例
import subprocess
# 創(chuàng)建一個(gè)子進(jìn)程去執(zhí)行系統(tǒng)命令
obj=subprocess.Popen(
'ps -ef', # 執(zhí)行的系統(tǒng)命令(必須是字符串格式)
shell=True, # 指定命令解釋器來解釋執(zhí)行的這條命令
stdout=subprocess.PIPE, # 將執(zhí)行的正確結(jié)果丟到管道(共享內(nèi)存空間,用于進(jìn)程之間共享)
stderr=subprocess.PIPE # 將執(zhí)行的錯(cuò)誤結(jié)果丟到另一個(gè)新的管道
)
'''
當(dāng)從任意一個(gè)管道,例如正確或者錯(cuò)誤結(jié)果管道中獲取值,
'''
# 從正確管道中獲取值
res=obj.stdout.read() # 主進(jìn)程去管道里獲取正確的結(jié)果
print(res.decode('utf-8')) # 獲取的結(jié)果是bytes類型,需要指定decode指定編碼
# 從錯(cuò)誤管道中獲取值
res2=obj.stderr.read()
print(res2.decode('utf-8'))