从subprocess.Popen异步读取stdout

Mes*_*sut 6 python windows subprocess

我正在使用subprocess.popen运行子程序.当我从命令窗口(cmd.exe)启动我的Python程序时,程序会随着程序的发展在窗口中写入一些信息和日期.

当我不在命令窗口中运行我的Python代码时,它会为这个子程序的输出打开一个新的命令窗口,我想避免这种情况.当我使用以下代码时,它不会显示cmd窗口,但它也不会打印状态:

p = subprocess.Popen("c:/flow/flow.exe", shell=True, stdout=subprocess.PIPE)
print p.stdout.read()
Run Code Online (Sandbox Code Playgroud)

如何在程序输出中显示子程序的输出?

小智 8

用这个:

cmd = subprocess.Popen(["c:/flow/flow.exe"], stdout=subprocess.PIPE)
for line in cmd.stdout:
    print line.rstrip("\n")
cmd.wait()  # you may already be handling this in your current code
Run Code Online (Sandbox Code Playgroud)

请注意,您仍然需要等待子程序刷新其stdout缓冲区(在不写入终端窗口时通常以不同的方式缓冲),因此当子程序打印时,您可能无法立即看到每一行(这取决于各种OS细节和子程序的细节).

还要注意我是如何删除shell = True并用列表替换字符串参数,这通常是推荐的.

  • [`for line in iter(cmd.stdout.readline,""):print line,`](http://stackoverflow.com/questions/2804543/read-subprocess-stdout-line-by-line)可能提供通过可能避免文件迭代器中的预读缓冲区来更直接的输出(注意:子程序仍然必须刷新其标准输出) (2认同)
  • 不明白为什么这是异步的. (2认同)