p = subprocess.Popen(cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
out, err = p.communicate()
# do something with out, err, or don’t bother altogether.
基本上,此方法会将所有
cmd输出“传递”到stdout和stderr到由准备的内存中缓冲区
subprocess。这些缓冲区的内容由您决定。您可以检查它们,也可以完全不去理会它们。但是,管道传递到这些缓冲区的副作用是它们不会被打印到终端的缓冲区中。
编辑 :这也可以使用便捷方法
call。进行演示:
>>> subprocess.call('ping 127.0.0.1')Pinging 127.0.0.1 with 32 bytes of data:Reply from 127.0.0.1: bytes=32 time<1ms TTL=128Reply from 127.0.0.1: bytes=32 time<1ms TTL=128Reply from 127.0.0.1: bytes=32 time<1ms TTL=128Reply from 127.0.0.1: bytes=32 time<1ms TTL=128Ping statistics for 127.0.0.1: Packets: Sent = 4, Received = 4, Lost = 0 (0% loss),Approximate round trip times in milli-seconds: Minimum = 0ms, Maximum = 0ms, Average = 0ms0>>> subprocess.call('ping 127.0.0.1', stdout=subprocess.PIPE)0编辑2
:注意
subprocess.call:
注意:请勿将此功能与stdout = PIPE或stderr =
PIPE一起使用。由于在当前进程中未读取管道,因此子进程如果向管道生成足够的输出以填满OS管道缓冲区,则子进程可能会阻塞。



