Subprocess wait()函数似乎没有等待子进程完成

时间:2011-06-16 20:37:26

标签: python subprocess wait communicate

我正在尝试使用python的子进程模块运行php脚本。

proc = subprocess.Popen(['php', '-f', test.php], stdout=subprocess.PIPE, stderr=subprocess.PIPE)

retCode = proc.wait

print retCode

val = float(kprocess.stdout.read())

return val

我也试过了:

proc = subprocess.Popen(['php', '-f', test.php], stdout=subprocess.PIPE, stderr=subprocess.PIPE)

val = float(kprocess.communicate()[0])

return val

当我在python解释器中运行它时,两种方式都在本地工作,但是当我尝试在实际服务器上运行它时,我总是得到“ValueError at / empty string for float()”。这让我相信这个过程在某种程度上没有被等待。我错过了什么?

编辑:我正在使用Django,所以当我使用Django运行时它似乎只会中断。

1 个答案:

答案 0 :(得分:5)

您必须实际调用进程'wait函数:

proc = subprocess.Popen(...)
retCode = proc.wait # retCode will be the function wait
retCode = proc.wait() # retCode will be the return code

但是,由于您要将输出重定向到,因此您应该注意wait文档中的警告并改为使用communicate。确保您的代码没有语法错误:

  • test.php可能不是变量名,而是字符串
  • 您混淆了两个变量名称prockprocess
  • 您正在盲目地解析communicate的结果(这不是严格意义上的错误,但可能会阻碍错误检测和跟踪)

相反,我建议:

proc = subprocess.Popen(['php', '-f', 'test.php'],
                        stdout=subprocess.PIPE, stderr=subprocess.PIPE)
stdout,stderr = proc.communicate()
if proc.returncode != 0:
    raise Exception('Test error: ' + stderr)
return float(stdout)