无法成功地将标准输出从Popen重定向到临时文件



标题说明了一切,真的。当前运行Python 2.7.8,使用subprocess32。最小复制片段,直接从REPL复制:

Python 2.7.8 (default, Aug 14 2014, 13:26:38)
[GCC 4.4.7 20120313 (Red Hat 4.4.7-4)] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> import tempfile
>>> import subprocess32 as subp
>>> tfil = tempfile.TemporaryFile()
>>> tfil
<open file '<fdopen>', mode 'w+b' at 0x7f79dcf158a0>
>>> proc = subp.Popen(['ls', '-al'], stdout=tfil, stderr=subp.STDOUT)
>>> proc
<subprocess32.Popen object at 0x7f79dcf04a50>
>>> proc.wait()
0
>>> tfil.read()
''
>>>

在任何组合中对结果没有影响的代码更改:

  • 使用subprocess代替subprocess32
  • 使用NamedTemporaryFile代替TemporaryFile
  • bufsize=0设置为tfilproc中的一个或两个
  • 如果我尝试subp.Popen(['ls', '-al'], stdout=sys.stdout, stderr=subp.STDOUT),输出重定向到终端很好-但我需要在其他地方捕获它,我不能只是将它与实际终端输出混合在一起。将sys.stdout重定向到临时文件,然后在进程完成后将其设置回来,也不起作用。

我需要这样做,因为我想在实际的非最小示例程序(qacct -j)中使用的命令的输出对于subprocess.PIPE来说太大了,引发了MemoryError(没有进一步的细节)。

我发现最相关的问题是这个,但它实际上没有帮助。

文件被正确写入,但是您的tfil.read()命令将在最后一次写入的位置开始读取,因此它将不返回任何内容。你需要先呼叫tfil.seek(0)

最新更新