3

好吧,我有两个脚本。打印 b.py 脚本输出的 a.py 如下:

#a.py
from subprocess import Popen, PIPE, STDOUT

p = Popen(['/Users/damian/Desktop/b.py'], shell=False, stdout=PIPE, stderr=STDOUT)

while p.poll() is None:
    print p.stdout.readline()


#b.py
#!/usr/bin/env python
import time

while 1:
    print 'some output'
    #time.sleep(1)

这行得通。但是,当我取消注释 time.sleep() 行时,为什么我的脚本会死锁?

4

2 回答 2

5

您的输出可能已缓冲。为标准输出添加.flush()以清除它:

import sys
import time

while 1:
    print 'someoutput'
    sys.stdout.flush()
    time.sleep(1)
于 2012-10-01T19:37:45.050 回答
2

如果您添加-u到调用a.py(使输出无缓冲),那么您不需要修改b.py脚本:

import sys
from subprocess import Popen, PIPE, STDOUT

p = Popen([sys.executable, '-u', '/Users/damian/Desktop/b.py'],
          stdout=PIPE, stderr=STDOUT, close_fds=True)
for line in iter(p.stdout.readline, ''):
    print line,
p.stdout.close()
if p.wait() != 0:
   raise RuntimeError("%r failed, exit status: %d" % (cmd, p.returncode))

查看更多从子流程获取输出的方法

于 2012-10-01T20:38:56.350 回答