阻止subprocess.Popen在python中显示输出

时间:2012-12-24 16:15:44

标签: python subprocess

所以我试图将命令的输出存储到变量中。我不希望它在运行命令时显示输出...

我现在的代码如下......

def getoutput(*args):
    myargs=args
    listargs=[l.split(' ',1) for l in myargs]
    import subprocess
    output=subprocess.Popen(listargs[0], shell=False ,stdout=subprocess.PIPE)   
    out, error = output.communicate()
    return(out,error)


def main():

    a,b=getoutput("httpd -S")

if __name__ == '__main__':
    main()

如果我把它放在一个文件中并在命令行上执行它。即使我在代码中没有print语句,我也得到以下输出。如何在保存输出的同时防止这种情况?

#python ./apache.py 
httpd: Could not reliably determine the server's fully qualified domain name, using xxx.xxx.xxx.xx for ServerName
Syntax OK

2 个答案:

答案 0 :(得分:21)

您所看到的是标准错误输出,而不是标准输出输出。 Stderr重定向由stderr构造函数参数控制。它默认为None,这意味着不会发生重定向,这就是您看到此输出的原因。

通常保持stderr输出是个好主意,因为它有助于调试并且不会影响正常的重定向(例如|> shell重定向默认情况下不会捕获stderr)。但是你可以像使用stdout一样将它重定向到其他地方:

sp = subprocess.Popen(listargs[0], shell=False,
    stdout=subprocess.PIPE, stderr=subprocess.PIPE)
output, error = sp.communicate()

或者你可以放弃stderr:

devnull = open(os.devnull, 'wb') #python >= 2.4
sp = subprocess.Popen(listargs[0], shell=False,
    stdout=subprocess.PIPE, stderr=devnull)

#python 3.x:
sp = subprocess.Popen(listargs[0], shell=False
    stdout=subprocess.PIPE, stderr=subprocess.DEVNULL)

答案 1 :(得分:2)

你正在捕捉stdout,但是你没有抓住stderr(标准错误),我认为这是消息的来源。

output=subprocess.Popen(listargs[0], shell=False ,stdout=subprocess.PIPE, stderr=STDOUT)

这会将stderr中的任何内容放入与stdout相同的位置。