Windows 7 64位上的Python子进程 - 当stdout = PIPE时没有输出

时间:2012-10-06 11:39:47

标签: python windows subprocess popen

关于Python子进程的另一个问题的道歉,但我找不到这个问题的答案。

我遇到了一些在Windows 7 64位上调用子进程的Python代码。当子进程的stdout发送到管道时,不会产生任何输出。该子进程似乎没有问题地运行和终止,它只是不产生任何输出。

编辑:相同的代码在WinXP 32bit上正常工作,所以我更新了问题标题。

# (listing 1)
from subprocess import *
#cmdline= (a valid command line)
proc = Popen(cmdline,shell=True,stdout=PIPE,stderr=PIPE)
out, err = proc.communicate()
print( out )
print( err )

这给出了输出

out:

err:

但是,当子进程的输出未通过管道传输时,它会按预期生成输出:

# (listing 2)
proc = Popen(cmdline,shell=True)
proc.communicate()

这为控制台提供了预期的输出。

我确信可执行文件实际上是将其输出写入stdout。我有C源代码,我添加了一行:

fprintf(stdout, "HELLO");

同样,在运行清单2时会看到“HELLO”,但不会列出清单1.

我还尝试制作一个新的C ++可执行文件并从cmdline调用它:

#include <iostream>

int main()
{
    std::cout << "HELLO" << std::endl;
}

同样的事情仍然发生 - 运行清单2时会看到“HELLO”,但不会列出清单1.

如果我将cmdline设置为'dir',则列表1和列表2都会出现预期的情况 - 目录内容将打印到控制台。

我尝试过的其他事情:Python 3.3和Python 2.7(结果相同); bufsize = 0(相同的结果);检查proc.returncode(它是0,如预期的那样);删除stderr = PIPE(在这种情况下,列表1按预期给出“错误:无”)。

编辑 - 我也尝试了= proc.stdout而不是带有相同结果的communic()方法。 Python文档和其他问题表明,communication()方法是正确使用的方法。

1 个答案:

答案 0 :(得分:2)

根本不是Python问题。我的防火墙设置已经“沙盒化”了可执行文件,这导致它们的输出被丢弃而没有任何警告或错误。

阻止它们执行会更有意义。我想我需要使用不同的防火墙软件。