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