问题描述
我无法弄清楚如何使用python的subprocess.run捕获stdout,stderr和exitcode ...以及其他任何可以捕获的东西。我还必须使用timeout选项,因为我正在运行的成千上万个命令中的一些挂起了,即无限运行。我敢打赌,我错过了一些明显的事情,对不起。我已经花了几天时间,无法解决。
您能给我的任何帮助将不胜感激。
这是我的有缺陷的代码:
seconds = timeout
try:
proc = subprocess.run(cmd,capture_output=True,timeout=seconds)
except subprocess.TimeoutExpired:
print('This process ran too long:\n' + cmd + '\n')
out,err = proc.communicate()
exitcode = proc.returncode
if len(out) == 0: out="''"
if len(err) == 0: err="''"
#
return exitcode,out,err
解决方法
您快到了。代替
out,err = proc.communicate()
使用
out,err = proc.stdout,proc.stderr
关于您的except子句,我不确定超时后是否能够获取stdout,stderr和returncode。给它一张支票。如果没有,请考虑在您的except子句中使用return "","",1
或类似的内容。