python中執行指令的3種方法小結

大家讲道理
發布: 2016-11-07 16:42:03
原創
949 人瀏覽過

目前我使用到的python中執行cmd的方式有三種:

1. 使用os.system("cmd")

特點是執行的時候程式會打出cmd在linux上執行的資訊。

import os
os.system("ls")
登入後複製

2. 使用Popen模組產生新的process

現在大部分人都喜歡使用Popen。 Popen方法不會列印出cmd在linux上執行的資訊。的確,Popen非常強大,支援多種參數和模式。使用前需要from subprocess import Popen, PIPE。但是Popen函數有一個缺陷,就是它是一個阻塞的方法。如果執行cmd時產生的內容非常多,函數就非常容易阻塞住。解決辦法是不使用wait()方法,但是也不能得到執行的回傳值了。

Popen原型是:

subprocess.Popen(args, bufsize=0, executable=None, stdin=None, stdout=None, stderr=None, preexec_fn=None, close_fout=None, stderr=None, preexec_fn=None, close_ff=False, shell 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。

例如:

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。

例如:

status, output = commands.getstatusoutput("ls")
登入後複製

還有隻獲得output和status的方法:

commands.getoutput("ls")  
commands.getstatus("ls")
登入後複製


來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!