⑴ python 中os.system()的用法
os模塊中的system()函數可以方便地運行其他程序或者腳本。
語法如下:os.system(command)
其參數含義如下所示:
command 要執行的命令,相當於在Windows的cmd窗口中輸入的命令。如果要向程序或者腳本傳遞參數,可以使用空格分隔程序及多個參數。
(1)pythonossystem和擴展閱讀
Python在執行時,首先會將.py文件中的源代碼編譯成Python的byte code(位元組碼),然後再由Python Virtual Machine(Python虛擬機)來執行這些編譯好的byte code。這種機制的基本思想跟Java,.NET是一致的。然而,Python Virtual Machine與Java或.NET的Virtual Machine不同的是,Python的Virtual Machine是一種更高級的Virtual Machine。
這里的高級並不是通常意義上的高級,不是說Python的Virtual Machine比Java或.NET的功能更強大,而是說和Java 或.NET相比,Python的Virtual Machine距離真實機器的距離更遠。或者可以這么說,Python的Virtual Machine是一種抽象層次更高的Virtual Machine。
基於C的Python編譯出的位元組碼文件,通常是.pyc格式。
除此之外,Python還可以以交互模式運行,比如主流操作系統Unix/linux、Mac、Windows都可以直接在命令模式下直接運行Python交互環境。直接下達操作指令即可實現交互操作。
⑵ python 基礎知識——os.system 函數的騷操作
Python中os.system函數的幾個「騷操作」及解釋:
直接執行操作系統命令:
注意當前工作目錄:
支持執行多條命令:
在伺服器管理中的應用:
手動操作的細心要求:
⑶ python os.system、os.popen、subprocess.Popen的區別
1、使用os.system("cmd")
這是最簡單的一種方法,其執行過程中會輸出顯示cmd命令執行的信息。
例如:print os.system("mkdir test") >>>輸出:0
可以看到結果列印出0,表示命令執行成功;否則表示失敗(再次執行該命令,輸出:子目錄或文件 test 已經存在。1)。
2、使用os.popen("cmd")
通過os.popen()返回的是 file read 的對象,對其進行讀取read()操作可以看到執行的輸出
例如:print os.popen("adb shell ls /sdcard/ | findstr aa.png").read() >>> 輸出:aa.png(若aa.png存在,否則輸出為空)
3、subprocess.Popen("cmd")
subprocess模塊被推薦用來替換一些老的模塊和函數,如:os.system、os.spawn*、os.popen*等
subprocess模塊目的是 啟動一個新的進程並與之通信 ,最常用是定義類Popen,使用Popen可以創建進程,並與進程進行復雜的交互。其函數原型為:
classsubprocess.Popen(args, bufsize=0, executable=None, stdin=None, stdout=None, stderr=None, preexec_fn=None, close_fds=False, shell=False, cwd=None, env=None, universal_newlines=False, startupinfo=None, creationflags=0)
Popen非常強大,支持多種參數和模式,通過其構造函數可以看到支持很多參數。但Popen函數存在缺陷在於, 它是一個阻塞的方法 ,如果運行cmd命令時產生內容非常多,函數就容易阻塞。另一點, Popen方法也不會列印出cmd的執行信息 。
以下羅列常用到的參數:
args :這個參數必須是 字元串 或者是一個由 字元串成員的列表 。其中如果是一個字元串列表的話,那第一個成員為要運行的程序的路徑以及程序名稱;從第二個成員開始到最後一個成員為運行這個程序需要輸入的參數。這與popen中是一樣的。
bufsize: 一般使用比較少,略過。
executable: 指定要運行的程序,這個一般很少用到,因為要指定運行的程序在args中已經指定了。 stdin,stdout ,stderr: 分別代表程序的標准輸入、標准輸出、標准錯誤處理。可以選擇的值有 PIPE , 已經存在的打開的文件對象 和 NONE 。若stdout是文件對象的話,要確保文件對象是處於打開狀態。
shell:shell參數根據要執行的命令情況來定,如果將參數shell設為True,executable將指定程序使用的shell。在windows平台下,默認的shell由COMSPEC環境變數來指定。
⑷ python調用OS.system結束進程問題
os.system是執行命令,是否列印取決於命令是否有返回
如果你想不讓其列印 可以在命令中做手腳如: os.system('taskkill /IM dllhost.exe > NUL')
⑸ python 中os.system和commands.getoutput的區別
1. 使用os.system("cmd")
這是最簡單的一種方法,特點是執行的時候程序會打出cmd在linux上執行的信息。使用前需要import os。
[python]
os.system("ls")
2. 使用Popen模塊產生新的process
現在大部分人都喜歡使用Popen。Popen方法不會列印出cmd在linux上執
行的信息。的確,Popen非常強大,支持多種參數和模式。使用前需要from subprocess import Popen,
PIPE。但是Popen函數有一個缺陷,就是它是一個阻塞的方法。如果運行cmd時產生的內容非常多,函數非常容易阻塞住。解決辦法是不使用
wait()方法,但是也不能獲得執行的返回值了。
Popen原型是:
[python]
subprocess.Popen(args, bufsize=0, executable=None, stdin=None, stdout=None, stderr=None, preexec_fn=None, close_fds=False, shell=False, cwd=None, env=None, universal_newlines=False, startupinfo=None, creationflags=0)
參數bufsize:指定緩沖。我到現在還不清楚這個參數的具體含義,望各個大牛指點。
參數executable用於指定可執行程序。一般情況下我們通過args參數來設置所要運行的程序。如果將參數shell設為 True,executable將指定程序使用的shell。在windows平台下,默認的shell由COMSPEC環境變數來指定。
參數stdin, stdout, stderr分別表示程序的標准輸入、輸出、錯誤句柄。他們可以是PIPE,文件描述符或文件對象,也可以設置為None,表示從父進程繼承。
參數preexec_fn只在Unix平台下有效,用於指定一個可執行對象(callable object),它將在子進程運行之前被調用。
參數Close_sfs:在windows平台
下,如果close_fds被設置為True,則新創建的子進程將不會繼承父進程的輸入、輸出、錯誤管
道。我們不能將close_fds設置為True同時重定向子進程的標准輸入、輸出與錯誤(stdin, stdout, stderr)。
如果參數shell設為true,程序將通過shell來執行。
參數cwd用於設置子進程的當前目錄。
參數env是字典類型,用於指定子進程的環境變數。如果env = None,子進程的環境變數將從父進程中繼承。
參數Universal_newlines:不同操作系統下,文本的換行符是不一樣的。如:windows下用』/r/n』表示換,而Linux下用 『/n』。如果將此參數設置為True,Python統一把這些換行符當作』/n』來處理。
參數startupinfo與createionflags只在windows下用效,它們將被傳遞給底層的CreateProcess()函數,用 於設置子進程的一些屬性,如:主窗口的外觀,進程的優先順序等等。
subprocess.PIPE
在創建Popen對象時,subprocess.PIPE可以初始化stdin, stdout或stderr參數,表示與子進程通信的標准流。
subprocess.STDOUT
創建Popen對象時,用於初始化stderr參數,表示將錯誤通過標准輸出流輸出。
Popen的方法:
Popen.poll()
用於檢查子進程是否已經結束。設置並返回returncode屬性。
Popen.wait()
等待子進程結束。設置並返回returncode屬性。
Popen.communicate(input=None)
與子進程進行交互。向stdin發送數據,或從stdout和stderr中讀取數據。可選參數input指定發送到子進程的參數。
Communicate()返回一個元組:(stdoutdata,
stderrdata)。注意:如果希望通過進程的stdin向其發送數據,在創建Popen對象的時候,參數stdin必須被設置為PIPE。同樣,如
果希望從stdout和stderr獲取數據,必須將stdout和stderr設置為PIPE。
Popen.send_signal(signal)
向子進程發送信號。
Popen.terminate()
停止(stop)子進程。在windows平台下,該方法將調用Windows API TerminateProcess()來結束子進程。
Popen.kill()
殺死子進程。
Popen.stdin
如果在創建Popen對象是,參數stdin被設置為PIPE,Popen.stdin將返回一個文件對象用於策子進程發送指令。否則返回None。
Popen.stdout
如果在創建Popen對象是,參數stdout被設置為PIPE,Popen.stdout將返回一個文件對象用於策子進程發送指令。否則返回 None。
Popen.stderr
如果在創建Popen對象是,參數stdout被設置為PIPE,Popen.stdout將返回一個文件對象用於策子進程發送指令。否則返回 None。
Popen.pid
獲取子進程的進程ID。
Popen.returncode
獲取進程的返回值。如果進程還沒有結束,返回None。
例如:
[python]
p = Popen("cp -rf a/* b/", shell=True, stdout=PIPE, stderr=PIPE)
p.wait()
if p.returncode != 0:
print "Error."
return -1
3. 使用commands.getstatusoutput方法
這個方法也不會列印出cmd在linux上執行的信息。這個方法唯一的優點是,它不是一個阻塞的方法。即沒有Popen函數阻塞的問題。使用前需要import commands。
例如:
[python]
status, output = commands.getstatusoutput("ls")
還有隻獲得output和status的方法:
[python]
commands.getoutput("ls")
commands.getstatus("ls")