Python中os.system()、subprocess.run()、call()、check_output()的使用案例
1.os.system()
os.system() 是對 C 語言中 system() 系統(tǒng)函數(shù)的封裝,允許執(zhí)行一條命令,并返回退出碼(exit code),命令輸出的內(nèi)容會直接打印到屏幕上,無法直接獲取。
示例:
# test.py import os os.system("ls -l | grep test") # 允許管道符 # 測試執(zhí)行 $ ll <======== 列出當前目錄中的內(nèi)容 drwxr-xr-x 2 foo foo 4096 Feb 13 09:09 __pycache__ -rw-r--r-- 1 foo foo 359 Feb 19 09:21 test.py $ python test.py -rw-r--r-- 1 foo foo 359 Feb 19 09:21 test.py <======== 只有名字包含 test 的文件被列出
2.subprocess.run()
Python 3.5 開始推薦使用這個方法執(zhí)行命令,其原型如下:
subprocess.run( args, *, stdin=None, input=None, stdout=None, stderr=None, capture_output=False, shell=False, cwd=None, timeout=None, check=False, encoding=None, errors=None, text=None, env=None, universal_newlines=None )
其中:
args: 可以是一個字符串(當 shell=True 時),也可以是一個列表(當 shell=False 時)
- stdin, stdout, stderr: 用于指定標準IO文件句柄,可以是:
subprocess.PIPE: 用作 stdout, stderr 參數(shù)的值時,可以從返回值對象中的 stdout 和 stderr 屬性中讀取輸出內(nèi)容 subprocess.STDOUT: 用作 stderr 參數(shù)的值時,相當于把標準錯誤重定向到標準輸入中) subprocess.DEVNULL: 用作 stdout, stderr 參數(shù)的值時,相當于把輸出內(nèi)容重定向到 /dev/null 用戶已經(jīng)打開的文件對象或描述符(整型數(shù)字)
capture_output: 當設(shè)置為 True 時,相當于 stdout 和 stderr 參數(shù)都設(shè)置為 True 了,可以通過返回值對象訪問標準輸出和標準錯誤內(nèi)容
shell: 當設(shè)置為 True 時,args 參數(shù)會當做一條命令字符串(支持管道、重定向操作);當它為 False 時,args 需是一個列表(并且不支持管道、重定向操作)
cwd: 指定執(zhí)行命令的目錄,默認為當前目錄
timeout: 指定命令執(zhí)行超時時間(按妙計),若執(zhí)行超時了,會 kill 掉命令并拋出 TimeoutExpired 異常
check: 當設(shè)置為 True 時,會自動檢測執(zhí)行退出碼,若不為0,則拋出 CalledProcessError 異常
text: 當設(shè)置為 True 時,stdin、stdout、stderr 會以“文本”模式打開(返回值對象中的 stdout、stderr 存儲文本內(nèi)容),否則返回值對象中 stdout、stderr 存儲的是字節(jié)序列
env: 用于設(shè)置程序執(zhí)行時繼承的環(huán)境變量等,默認與當前進程相同
該方法返回一個 CompletedProcess 對象,其中包含以下屬性:
- returncode: 執(zhí)行命令的退出碼
- stdout: 捕獲的標準輸出內(nèi)容(當 stdout 參數(shù)為 PIPE 時)。其格式默認為字節(jié)序列,除非 text 參數(shù)為 True (此時為文本格式)。
- stderr: 捕獲的標準錯誤內(nèi)容(當 stderr 參數(shù)為 PIPE 時)。其格式默認為字節(jié)序列,除非 text 參數(shù)為 True (此時為文本格式)。
- args: 同參數(shù) args 。
示例:
import subprocess subprocess.run(["ls", "-l"]) # 默認時,args 參數(shù)需是一個列表 subprocess.run("ls -l", shell=True) # 當 shell 為 True 時,args 是一個字符串 ret = subprocess.run("ls -l", shell=True, capture_output=True, text=True) # 以文本模式捕獲輸出內(nèi)容 print("Return code:", ret.returncode) # Return code: 0 print("STDOUT:", ret.stdout) # STDOUT: ...當前目錄內(nèi)容... print("STDERR:", ret.stderr) # STDERR: <空> ret = subprocess.run("abcdefg", shell=True, text=True, # 注意:這里必須 shell=True 才能捕獲到 /bin/sh 的輸出錯誤 # 當 shell=False 時,是要去捕獲 "abcdefg" 命令自身輸出的內(nèi)容,但是它不存在,python 會報錯 stdout=subprocess.PIPE, stderr=subprocess.STDOUT # 標準錯誤重定向到標準輸出 ) print("STDOUT:", ret.stdout) # STDOUT: /bin/sh: abcdefg: command not found
另一個用于測試 shell 參數(shù)區(qū)別的示例如下:
import sys, re, subprocess if len(sys.argv) == 1: # parent process cmd = ["python", sys.argv[0], "--run-child"] ret = subprocess.run(cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE, text=True) print(ret) # CompletedProcess(args=['python', 'test.py', '--run-child'], returncode=0, stdout='stdout output\n', stderr='stderr output') assert re.match("stdout output", ret.stdout) assert re.match("stderr output", ret.stderr) # 如果 cmd 中的命令不存在,這里是捕獲不到的,subprocess.run()自己就會報錯 ret = subprocess.run(" ".join(cmd), shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE, text=True) print(ret) # CompletedProcess(args='python test.py --run-child', returncode=0, stdout='stdout output\n', stderr='stderr output') assert re.match("stdout output", ret.stdout) assert re.match("stderr output", ret.stderr) # 如果 cmd 中的命令不存在,這里也是可以捕獲到的,內(nèi)容可能是 xxx command not found print("Passed!") else: # child process print("stdout output") sys.stderr.write("stderr output")
3.subprocess.call()
Python 3.5 以前(包括 2.x 版本)沒有 subprocess.run() 方法,可以使用 subprocess.call() 來執(zhí)行命令,該方法原型如下:
subprocess.call(args, *, stdin=None, stdout=None, stderr=None, shell=False, cwd=None, timeout=None)
注意:這個方法的返回值是命令的退出碼,而不是一個對象,所以無法像 subprocess.run() 一樣捕獲命令輸出內(nèi)容(不要設(shè)置 stdout=PIPE 或 stderr=PIPE,否則可能造成命令卡死)。
該方法的其它參數(shù)與 subprocess.run() 類似。
4.subprocess.check_output()
Python 3.5 以前的版本,要想捕獲命令輸出內(nèi)容,可以使用 subprocess.check_output() 方法,它的原型如下:
subprocess.check_output(args, *, stdin=None, stderr=None, shell=False, cwd=None, encoding=None, errors=None, universal_newlines=None, timeout=None, text=None)
注意:參數(shù)中沒有 stdout ,因為這個函數(shù)的返回值默認就是標準輸出內(nèi)容,也可以將設(shè)置 stderr=subprocess.STDOUT 將標準錯誤重定向到標準輸出,但是好像沒有辦法單獨捕獲標準錯誤內(nèi)容呢!
示例:
import sys, re, subprocess if len(sys.argv) == 1: # parent process cmd = ["python", sys.argv[0], "--run-child"] ret = subprocess.check_output(cmd, stderr=subprocess.STDOUT) print("[" + ret + "]") # 輸出內(nèi)容中包含標準輸出和標準錯誤,輸出順序在 windows 下和 linux 下可能會有差異 assert re.search("stdout output", ret) assert re.search("stderr output", ret) print("Passed!") else: # child process print("stdout output") sys.stderr.write("stderr output")
到此這篇關(guān)于Python中os.system()、subprocess.run()、call()、check_output()的使用方法的文章就介紹到這了,更多相關(guān)Python中os.system()、subprocess.run()、call()、check_output()內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用Python和大模型進行數(shù)據(jù)分析和文本生成
Python語言以其簡潔和強大的特性,成為了數(shù)據(jù)科學、機器學習和人工智能開發(fā)的首選語言之一,在這篇文章中,我將介紹如何用Python連接和使用大模型,并通過示例展示如何在實際項目中應(yīng)用這些技術(shù),需要的朋友可以參考下2024-05-05