天天看點

python 執行shell_Python調用shell指令常用方法

Python調用shell指令

方法一、使用os子產品的system方法:os.system(cmd),其傳回值是shell指令運作後傳回的狀态碼,int類型,0表示shell指令成功執行,256表示未找到,該方法适用于shell指令不需要輸出内容的場景。

舉例說明:

1. 列舉目前目錄下的所有檔案。

1 importos2 val = os.system('ls -al')3 print val

python 執行shell_Python調用shell指令常用方法

沒有找到時,sh傳回的狀态碼是1,而适用python調用,傳回的是:256

python 執行shell_Python調用shell指令常用方法

方法二、使用os.popen(),該方法以檔案的形式傳回shell指令運作後的結果,需要擷取内容時可使用read()或readlines()方法,舉例如下:

python 執行shell_Python調用shell指令常用方法
python 執行shell_Python調用shell指令常用方法

方法三、使用commands子產品,有三個方法可以使用:

(1)commands.getstatusoutput(cmd),其以字元串的形式傳回的是輸出結果和狀态碼,即(status,output)。

(2)commands.getoutput(cmd),傳回cmd的輸出結果。

(3)commands.getstatus(file),傳回ls -l file的執行結果字元串,調用了getoutput,不建議使用此方法

python 執行shell_Python調用shell指令常用方法
python 執行shell_Python調用shell指令常用方法

方法四、subprocess子產品,允許建立很多子程序,建立的時候能指定子程序和子程序的輸入、輸出、錯誤輸出管道,執行後能擷取輸出結果和執行狀态。

(1)subprocess.run():python3.5中新增的函數, 執行指定的指令, 等待指令執行完成後傳回一個包含執行結果的CompletedProcess類的執行個體。

(2)subprocess.call():執行指定的指令, 傳回指令執行狀态, 功能類似os.system(cmd)。

(3)subprocess.check_call():python2.5中新增的函數, 執行指定的指令, 如果執行成功則傳回狀态碼, 否則抛出異常。

說明:subprocess.run(args, *, stdin=None, input=None, stdout=None, stderr=None, shell=False, timeout=None, check=False, universal_newlines=False)

subprocess.call(args, *, stdin=None, stdout=None, stderr=None, shell=False, timeout=None)

subprocess.check_call(args, *, stdin=None, stdout=None, stderr=None, shell=False, timeout=None)

args:表示shell指令,若以字元串形式給出shell指令,如"ls -l "則需要使shell = Ture。否則預設已數組形式表示shell變量,如"ls","-l"。

當使用比較複雜的shell語句時,可以先使用shlex子產品的shlex.split()方法來幫助格式化指令,然後在傳遞給run()方法或Popen。

python 執行shell_Python調用shell指令常用方法
python 執行shell_Python調用shell指令常用方法

附上python2.7中的subprocess子產品源碼供了解(pycharm檢視方法源碼,ctrl+左鍵)。

#Stubs for subprocess

#Based on http://docs.python.org/2/library/subprocess.html and Python 3 stub

from typing importSequence, Any, Mapping, Callable, Tuple, IO, Union, Optional, List, Text

_FILE=Union[None, int, IO[Any]]

_TXT=Union[bytes, Text]

_CMD=Union[_TXT, Sequence[_TXT]]

_ENV=Union[Mapping[bytes, _TXT], Mapping[Text, _TXT]]#Same args as Popen.__init__

defcall(args: _CMD,

bufsize: int=...,

executable: _TXT=...,

stdin: _FILE=...,

stdout: _FILE=...,

stderr: _FILE=...,

preexec_fn: Callable[[], Any]=...,

close_fds: bool=...,

shell: bool=...,

cwd: _TXT=...,

env: _ENV=...,

universal_newlines: bool=...,

startupinfo: Any=...,

creationflags: int= ...) ->int: ...defcheck_call(args: _CMD,

bufsize: int=...,

executable: _TXT=...,

stdin: _FILE=...,

stdout: _FILE=...,

stderr: _FILE=...,

preexec_fn: Callable[[], Any]=...,

close_fds: bool=...,

shell: bool=...,

cwd: _TXT=...,

env: _ENV=...,

universal_newlines: bool=...,

startupinfo: Any=...,

creationflags: int= ...) ->int: ...#Same args as Popen.__init__ except for stdout

defcheck_output(args: _CMD,

bufsize: int=...,

executable: _TXT=...,

stdin: _FILE=...,

stderr: _FILE=...,

preexec_fn: Callable[[], Any]=...,

close_fds: bool=...,

shell: bool=...,

cwd: _TXT=...,

env: _ENV=...,

universal_newlines: bool=...,

startupinfo: Any=...,

creationflags: int= ...) ->bytes: ...

PIPE= ... #type: int

STDOUT = ... #type: int

classCalledProcessError(Exception):

returncode=0#morally: _CMD

cmd = ... #type: Any

#morally: Optional[bytes]

output = ... #type: Any

def __init__(self,

returncode: int,

cmd: _CMD,

output: Optional[bytes]= ...) ->None: ...classPopen:

stdin= ... #type: Optional[IO[Any]]

stdout = ... #type: Optional[IO[Any]]

stderr = ... #type: Optional[IO[Any]]

pid =0

returncode=0def __init__(self,

args: _CMD,

bufsize: int=...,

executable: Optional[_TXT]=...,

stdin: Optional[_FILE]=...,

stdout: Optional[_FILE]=...,

stderr: Optional[_FILE]=...,

preexec_fn: Optional[Callable[[], Any]]=...,

close_fds: bool=...,

shell: bool=...,

cwd: Optional[_TXT]=...,

env: Optional[_ENV]=...,

universal_newlines: bool=...,

startupinfo: Optional[Any]=...,

creationflags: int= ...) ->None: ...def poll(self) ->int: ...def wait(self) ->int: ...#morally: -> Tuple[Optional[bytes], Optional[bytes]]

def communicate(self, input: Optional[_TXT] = ...) ->Tuple[Any, Any]: ...def send_signal(self, signal: int) ->None: ...def terminate(self) ->None: ...def kill(self) ->None: ...def __enter__(self) -> 'Popen': ...def __exit__(self, type, value, traceback) ->bool: ...#Windows-only: STARTUPINFO etc.

STD_INPUT_HANDLE= ... #type: Any

STD_OUTPUT_HANDLE = ... #type: Any

STD_ERROR_HANDLE = ... #type: Any

SW_HIDE = ... #type: Any

STARTF_USESTDHANDLES = ... #type: Any

STARTF_USESHOWWINDOW = ... #type: Any

CREATE_NEW_CONSOLE = ... #type: Any

CREATE_NEW_PROCESS_GROUP = ... #type: Any