Python常用外部指令執行程式碼例項
阿新 • • 發佈:2020-11-06
1、os.system()
阻塞
螢幕會列印命令的輸出
返回命令結果碼
# -*- encoding=utf-8 -*- import os if __name__ == '__main__': pass print('開始') ret1 = os.system('python') print('ret1:{}'.format(ret1)) ret2 = os.system('java -version') print('ret2:{}'.format(ret2)) print('結束')
執行
可能有人理解阻塞是因為運行了python,因此我嘗試兩個命令都用java -version
# -*- encoding=utf-8 -*- import os if __name__ == '__main__': pass print('開始') ret1 = os.system('java -version') print('ret1:{}'.format(ret1)) ret2 = os.system('java -version') print('ret2:{}'.format(ret2)) print('結束')
執行
2、os.popen()
阻塞或不阻塞
螢幕不會打印出命令的輸出
返回檔案物件,可用read,readline讀取
不阻塞時:
# -*- encoding=utf-8 -*- import os if __name__ == '__main__': pass print('開始') os.popen('python') ret2 = os.popen('java -version') print('結束')
執行(程式很快列印開始和結束,就像只用了兩個print語句一樣快)
阻塞時:
# -*- encoding=utf-8 -*- import os if __name__ == '__main__': pass print('開始') ret1 = os.popen('python') print(ret1.read()) ret2 = os.popen('java -version') print(ret2.read()) print('結束')
執行
3、commands.getstatusoutput
python2.+中使用
需要到linux執行
阻塞或者非阻塞
螢幕不會打印出命令的輸出
非阻塞時
# -*- encoding=utf-8 -*- import commands if __name__ == '__main__': pass print('開始') ret1 = commands.getstatusoutput('python') ret2 = commands.getstatusoutput('java -version') print('結束')
執行
阻塞時:
# -*- encoding=utf-8 -*- import commands if __name__ == '__main__': pass print('開始') ret1 = commands.getstatusoutput('python') print ret1[0] print ret1[1] print '==============' ret2 = commands.getstatusoutput('java -version') print ret2[0] print ret2[1] print '==============' print('結束')
執行
4、subprocess中Popen
阻塞或非阻塞,同上面一樣,通過是否讀取IO決定是否阻塞
螢幕會打印出命令的輸出
可通過stdout,stderr引數指定輸出或錯誤列印到檔案
# -*- encoding=utf-8 -*- import subprocess if __name__ == '__main__': pass print('開始') s1 = subprocess.Popen('python') s1.wait() s2 = subprocess.Popen('java -version') s2.wait() print('結束')
執行
4.1、 輸出到檔案
通過檔案物件來輸出到檔案中
# -*- encoding=utf-8 -*- import subprocess if __name__ == '__main__': pass print('開始') with open('s1.txt','w') as f: s1 = subprocess.Popen('python',stdout=f,) # 指定輸出重定向到檔案 s1.wait(10) # 超過10秒還沒執行完會丟擲異常 with open('s2.txt','w') as f: s2 = subprocess.Popen('java -version',stderr=f) # 指定輸出和錯誤都重定向到檔案 s2.wait() print('結束')
執行後可看到檔案已經寫入,螢幕不列印。需要注意是stdout還是stderr。
4.2、捕獲輸出和錯誤
PIPE通過開一個新的管道來接收執行狀態
# -*- encoding=utf-8 -*- import subprocess if __name__ == '__main__': pass print('開始') s1 = subprocess.Popen('java -version',stdout=subprocess.PIPE,stderr=subprocess.PIPE) s1.wait(10) # 超過10秒還沒執行完會丟擲異常 print(s1.returncode) # 結果碼 print(s1.poll()) # 已經執行結束返回結果碼,否則返回None std1 = s1.stdout.read() print('std_out:{}'.format(std1)) std2 = s1.stderr.read() print('std_err:{}'.format(std2)) print('結束')
執行
5、subprocess.call
用來替代os.system
阻塞
# -*- encoding=utf-8 -*- import subprocess if __name__ == '__main__': pass print('開始') s1 = subprocess.call('java -version',) print(s1) s2 = subprocess.call('python',) print(s2) s3 = subprocess.call('python',timeout=3) # 超時丟擲異常 print(s3) print('結束')
6、check_call()和check_output()
都會檢查結果碼,不是0就丟擲異常
check_call()返回狀態碼
check_output()返回輸出
# -*- encoding=utf-8 -*- import subprocess if __name__ == '__main__': pass print('開始') s1 = subprocess.check_call('java -version',) print(s1) s2 = subprocess.check_output('java -version',) print(s2) print('結束')
執行
使用上面提到的三個方法:call()、check_call() 和 check_output() 時,儘量不要將引數stderr和stdout設定為 subprocess.PIPE,這幾個函式預設都會等待子程序完成,子程序產生大量的輸出資料如果造成管道堵塞,父程序再等待子程序完成可能造成死鎖。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。