我有一个 Python 脚本来管理一系列CasperJS任务并处理结果。它从命令行运行良好,但是当我在 cron 中运行脚本时,出现错误:
CalledProcessError: Command '['/path/to/casperjs', '/path/to/doSomething.js', 'args']' returned non-zero exit status 1
在 Python 中,我调用 CasperJS:
response = subprocess.check_output(['/path/to/casperjs', '/path/to/doSomething.js', 'args'], shell=True)
我也尝试过shell=False
,Popen
但我得到了相同的结果。我还尝试将整个命令设为字符串(而不是列表),但这也无济于事。
在 shell 中运行时,运行'/path/to/casperjs /path/to/doSomething.js args'
返回退出代码 0。
我也添加PATH=/usr/bin:/bin:/sbin:/usr/local/bin
到我的 crontab 中无济于事。(正如这个问题所建议的那样。)
任何想法为什么我只在 cron 中得到这个错误?谢谢!!
编辑:根据下面的答案,设置shell=False
并使stderr=subprocess.STDOUT
一切正常......