2

我想在 python 脚本中操作控制台跟踪工具的输出。因此,我想读取该工具写入标准输出的每一行,并可能对该行执行某些操作并将其打印到屏幕上。

我有这个脚本:

import sys

for l in sys.stdin:
    print l

我像这样启动跟踪工具:

qspy -c COM7 | my_script.py

问题是当我第一次输入时:什么都没有发生。当我再次按 Enter 键时,我看到了该工具创建的所有输出,但它也退出了(跟踪工具在任何字符上退出)。我究竟做错了什么?

我在窗户上。


编辑:

我已经尝试了所有建议,但收效甚微:

首先,我创建了这个小脚本来在标准输出上产生一些输出:

import time

while 1:
    time.sleep(1)
    print "test"

这根本不起作用(没有输出):

import sys

for line in sys.stdin:
    print line,
    sys.stdout.flush() 

这个也没有做任何事情:

import fileinput, sys

for line in fileinput.input():
    print line,
    sys.stdout.flush()

这一个有效,但仅适用于测试脚本,不适用于 qspy:

import sys

for line in iter(sys.stdin.readline, ''):
    print line,
    sys.stdout.flush()

我确实这样调用脚本:

test.py | python -u my_script.py

并且还做了:

set PYTHONUNBUFFERED=1
4

1 回答 1

1

尝试禁用缓冲:

$ qspy -c COM7 | python -u my_script.py

您也可以尝试强制逐行阅读:

for line in iter(sys.stdin.readline, '')
    print line,

检查 qspy 是否有管理缓冲的选项。

您还可以设置PYTHONUNBUFFERED环境变量。

于 2012-07-09T17:54:28.217 回答