前言
其實有一個模塊也支持執(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基本工作原理:

Python之Subprocess模塊_第1張圖片

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'))