我想在python脚本中操作控制台跟踪工具的输出。所以我想阅读该工具写入stdout的每一行,并且可能对该行执行某些操作并将其打印到屏幕上。
我有这个脚本:
import sys
for l in sys.stdin:
print l
我启动跟踪工具:
qspy -c COM7 | my_script.py
问题是当我第一次进入时:没有任何反应。当我再次按Enter键时,我会看到该工具创建的所有输出,但它也会退出(trace-tool退出任何字符)。我做错了什么?
我在窗户上。
编辑:
我已经尝试了所有建议,收效甚微:
首先,我创建了这个小脚本,以便在stdout上生成一些输出:
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
答案 0 :(得分:1)
尝试禁用缓冲:
$ qspy -c COM7 | python -u my_script.py
你也可以尝试逐行强制阅读:
for line in iter(sys.stdin.readline, '')
print line,
检查是否有qspy有一个管理缓冲的选项。
您还可以设置PYTHONUNBUFFERED
环境变量。