前言
其實有一個模塊也支持執(zhí)行系統(tǒng)命令,那個模塊就是
sys.system
,但他執(zhí)行系統(tǒng)命令會直接通過主進(jìn)程去執(zhí)行命令,那假如,該命令的執(zhí)行需要耗費一個小時,那么
主進(jìn)程會
卡一個小時,而不會去干別的事,這樣就會導(dǎo)致程序的運(yùn)行效率低下。
如果由
subprocess
去
執(zhí)行系統(tǒng)命令
的時候并不會讓主進(jìn)程去執(zhí)行,而是主進(jìn)程會開辟出一個
子進(jìn)程
去執(zhí)行,并不會影響到
主進(jìn)程
的運(yùn)行,
主進(jìn)程
該干嘛就干嘛,那么又有個問題,大家都知道進(jìn)程之間的
內(nèi)存空間是獨立
的,也就是說
進(jìn)程之間
是不能
相互訪問
的,那么在
subprocess
中,有個管道的概念,既然固定死了
進(jìn)程之間不能相互訪問
,那么可以將執(zhí)行命令的結(jié)果輸出到管道里,該管道其實就是一塊
共享的內(nèi)存空間
,可以讓
主進(jìn)程
去
獲取到該共享內(nèi)存空間存放的數(shù)據(jù)
subprocess基本工作原理:
subprocess簡單案例
import subprocess
# 創(chuàng)建一個子進(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í)行的錯誤結(jié)果丟到另一個新的管道
)
'''
當(dāng)從任意一個管道,例如正確或者錯誤結(jié)果管道中獲取值,
'''
# 從正確管道中獲取值
res=obj.stdout.read() # 主進(jìn)程去管道里獲取正確的結(jié)果
print(res.decode('utf-8')) # 獲取的結(jié)果是bytes類型,需要指定decode指定編碼
# 從錯誤管道中獲取值
res2=obj.stderr.read()
print(res2.decode('utf-8'))
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯(lián)系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
