subprocess 模块运行用户生成新的进程,并连接它们的输入、输出、错误管道,并且获取它们的返回码。
subprocess.run() 函数可以使用 subprocess 模块的 subprocess.check_output() 函数来调用子进程。subprocess.run() 函数将运行 args 中描述的指令,指令完成后,返回一个 CompletedProcess 实例。
subprocess.run(
args,
stdin=None, stdout=None, stderr=None,
capture_output=False,
hell=False, cwd=None,
timeout=None,
check=False,
input=None,
encoding=None, errors=None, text=None,
env=None,
universal_newlines=None, **other_popen_kwargs
)
常用参数:
args,要执行的指令。capture_output, stdin, stdout, stderr
capture_output 设为 True,stdout 和 stderr 将会被捕获。内置的 Popen 对象将自动用 stdout=subprocess.PIPE 和 stderr=subprocess.PIPE 创建。stdout 和 stderr 参数不应当与 capture_output 同时提供。如果你希望捕获并将两个流合并在一起,使用 stdout=subprocess.PIPE 和 stderr=subprocess.STDOUT 来代替 capture_output。>>> a = subprocess.run(["ls", "-l", "/dev/null"], capture_output=True)
>>> a
CompletedProcess(args=['ls', '-l', '/dev/null'], returncode=0, stdout=b'crw-rw-rw- 1 root root 1, 3 Jun 25 00:52 /dev/null\n', stderr=b'')
>>> a.stdout
b'crw-rw-rw- 1 root root 1, 3 Jun 25 00:52 /dev/null\n'
>>> a.stderr
b''
>>>
>>>
>>> a = subprocess.run(["ls", "-ol", "/dev/null"], stdout=subprocess.PIPE, stderr=subprocess.STDOUT)
>>> a.stdout
b'crw-rw-rw- 1 root 1, 3 Jun 25 00:52 /dev/null\n'
>>> a.stderr
>>>
timeout,timeout 参数将被传递给 Popen.communicate()。如果发生超时,子进程将被杀死并等待。 TimeoutExpired 异常将在子进程中断后被抛出。input,input 参数将被传递给 Popen.communicate() 以及子进程的 stdin。 如果使用此参数,它必须是一个字节序列。 如果指定了 encoding 或 errors 或者将 text 设置为 True,那么也可以是一个字符串。 当使用此参数时,在创建内部 Popen 对象时将自动带上 stdin=PIPE,并且不能再手动指定 stdin 参数。check,如果 check 设为 True, 并且进程以非零状态码退出, 一个 CalledProcessError 异常将被抛出. 这个异常的属性将设置为参数, 退出码, 以及标准输出和标准错误, 如果被捕获到.encoding 或者 error 被指定, 或者 text 被设为 True, 标准输入, 标准输出和标准错误的文件对象将通过指定的 encoding 和 errors以文本模式打开, 否则以默认的 io.TextIOWrapper 打开. universal_newline 参数等同于 text 并且提供了向后兼容性. 默认情况下, 文件对象是以二进制模式打开的。subprocess 较早的 API 函数现在多数情况可以使用 run() 函数来完成,在 run() 函数之前常使用下面的这些函数。
subprocess.call() 函数subprocess.call(
args, *,
stdin=None,
stdout=None,
stderr=None,
shell=False,
cwd=None,
timeout=None,
**other_popen_kwargs
)
运行 args 所描述的命令。等待命令完成,然后返回 returncode 属性。
>>> a = subprocess.call(['ls', '-l'], stderr=subprocess.STDOUT)
-rwxrw-r-- 1 zzz zzz 69 May 12 12:28 test1.sh
-rwxrw-r-- 1 zzz zzz 88 May 12 12:40 test2.sh
-rwxrw-r-- 1 zzz zzz 91 May 12 12:45 test3.sh
>>> a
0
>>>
subprocess.check_call() 函数subprocess.check_call(
args, *,
stdin=None,
stdout=None,
stderr=None,
shell=False,
cwd=None,
timeout=None,
**other_popen_kwargs
)
执行 args 所描述的命令。等待命令完成。如果返回的状态码为0,则返回;否则,抛出 CalledProcessError。CalledProcessError 对象中有returncode属性的返回码。
subprocess.check_output() 函数subprocess.check_output(
args, *,
stdin=None,
stdout=None,
stderr=None,
shell=False,
cwd=None,
encoding=None,
errors=None,
universal_newlines=None,
timeout=None,
**other_popen_kwargs
)
附带参数运行命令并返回其输出。如果返回码非零则会引发 CalledProcessError。 CalledProcessError 对象将在 returncode 属性中保存返回码并在 output 属性中保存所有输出。
>>> subprocess.check_output(
... "ls non_existent_file; exit 0",
... stderr=subprocess.STDOUT,
... shell=True)
'ls: non_existent_file: No such file or directory\n'