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

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