1. 程式人生 > >python呼叫shell的方法

python呼叫shell的方法

【轉】http://www.jb51.net/article/43502.htm


這篇文章主要介紹了python呼叫shell的方法,python呼叫shell命令的方法有許多種,大家可以參考使用

1.1  os.system(command)

在一個子shell中執行command命令,並返回command命令執行完畢後的退出狀態。這實際上是使用C標準庫函式system()實現的。這個函式在執行command命令時需要重新開啟一個終端,並且無法儲存command命令的執行結果。

1.2  os.popen(command,mode)

開啟一個與command程序之間的管道。這個函式的返回值是一個檔案物件,可以讀或者寫(由mode決定,mode預設是'r')。如果mode為'r',可以使用此函式的返回值呼叫read()來獲取command命令的執行結果。

1.3  commands.getstatusoutput(command)

使用os. getstatusoutput ()函式執行command命令並返回一個元組(status,output),分別表示command命令執行的返回狀態和執行結果。對command的執行實際上是按照{command;} 2>&1的方式,所以output中包含控制檯輸出資訊或者錯誤資訊。output中不包含尾部的換行符。

2.1  subprocess.call(["some_command","some_argument","another_argument_or_path"])

subprocess.call(command,shell=True)

2.2  subprocess.Popen(command, shell=True)

如果command不是一個可執行檔案,shell=True不可省。
使用subprocess模組可以建立新的程序,可以與新建程序的輸入/輸出/錯誤管道連通,並可以獲得新建程序執行的返回狀態。使用subprocess模組的目的是替代os.system()、os.popen*()、commands.*等舊的函式或模組。
最簡單的方法是使用class subprocess.Popen(command,shell=True)。Popen類有Popen.stdin,Popen.stdout,Popen.stderr三個有用的屬性,可以實現與子程序的通訊。

將呼叫shell的結果賦值給python變數

複製程式碼程式碼如下:
handle = subprocess.Popen(command, shell=True, stdout=subprocess.PIPE)
print handle.communicate()[0]


在Python/wxPython環境下,執行外部命令或者說在Python程式中啟動另一個程式的方法一般有這麼幾個:

1、os.system(command)

2、wx.Execute(command, syn=wx.EXEC_ASYNC, callback=None)

若置syn為wx.EXEC_ASYNC則wx.Excute函式立即返回,若syn=wx.EXEC_SYNC則等待呼叫的程式結束後再返回。

callback是一個wx.Process變數,如果callback不為None且syn=wx.EXEC_ASYNC,則程式結束後將呼叫wx.Process.OnTerminate()函式。

os.system()和wx.Execute()都利用系統的shell,執行時會出現shell視窗。如在Windows下會彈出控制檯視窗,不美觀。下面的兩種方法則沒有這個缺點。

3、class subprocess.Popen

最簡單的用法是:

複製程式碼程式碼如下:
import subprocess

subprocess.Popen(command, shell=True)

如果command不是一個可執行檔案,shell=True不可省。

前面三個方法只能用於執行程式和開啟檔案,不能處理URL,開啟URL地址可用webbrowser模組提供的功能。

4、webbrowser.open(url)

呼叫系統預設瀏覽器開啟URL地址,如 webbrowser.open('http://www.jb51.net'),也可以利用
webbrowser.open('h:\python.zip')來執行程式。這樣可以不必區分是檔名還是URL,不知道在Linux下是否可行。
以上在Windows2000,Python2.4a1,wxPython 2.5.1執行。
modify:還有一種方式:subprocess.call(*args, **kwargs)