在Python中实时拦截来自另一个进程的stdout

Set*_*son 5 python perl process

我想运行一个系统进程,拦截输出,并在Python脚本中逐行实时修改它.

我最好的尝试,等待打印前完成的过程,是:

#!/usr/bin/env python
import subprocess

cmd = "waitsome.py"
proc = subprocess.Popen(cmd, shell=True, bufsize=256, stdout=subprocess.PIPE)
for line in proc.stdout:
    print ">>> " + line.rstrip()
Run Code Online (Sandbox Code Playgroud)

脚本waitsome.py只需每半秒打印一行:

#!/usr/bin/env python
import time
from sys import stdout

print "Starting"
for i in range(0,20):
    time.sleep(0.5)
    print "Hello, iteration", i
    stdout.flush()
Run Code Online (Sandbox Code Playgroud)

是否有一个简单的解决方案subprocess允许实时迭代输出?我必须使用线程吗?

曾几何时,我用Perl编写脚本,这是小菜一碟:

open(CMD, "waitsome.py |");
while (<CMD>) {
    print ">>> $_";
}
close(CMD);
Run Code Online (Sandbox Code Playgroud)

Ale*_*lli 14

循环遍历文件不可避免地会以相当大的块缓冲事物 - 这是所有Python 2.*实现的已知问题.它适用于Python 3.1,最终循环略有不同:

for line in proc.stdout:
    print(">>> " + str(line.rstrip()))
Run Code Online (Sandbox Code Playgroud)

如果升级到Python 3.1是不切实际的(我知道它通常是!),那么转向另一种方式并以老式的方式编写循环 - 以下版本的循环确实可以像Python 2中那样工作.*:

while True:
    line = proc.stdout.readline()
    if not line:
        break
    print ">>> " + line.rstrip()
Run Code Online (Sandbox Code Playgroud)