我正在尝试使用 subprocess 模块从 Python 运行 C 程序,将其输出捕获到变量中。代码如下所示:
process = Popen(["myprog", str(length), filename], stdout=PIPE, stderr=PIPE)
#wait for the process
result = process.communicate()
end=time()
print result
上面的代码有效 -result
显示为myprog
's stdout 输出和 stderr 输出(作为字符串)的 2 元组。
...但是,如果我更改print result
为print(result)
...
Traceback (most recent call last):
File "tests.py", line 26, in <module>
print(result)
ValueError: I/O operation on closed file
我完全被难住了,我什至不知道从哪里开始尝试解释这个!当然,我的程序无论如何都可以工作,但我真的很想知道为什么会这样,希望这将是一个有趣的问题。