为什么有时Python子进程在运行进程后无法获得正确的退出代码?
作者:互联网
我正在使用Python子进程在Windows 7上运行外部脚本.我正在尝试获取退出代码.
在案例1中,我运行python脚本test1.py.
test1.py
import sys
sys.exit(24) <--exit code
myscript1.py
import subprocess
process = subprocess.Popen(["python", "C:\\path\\to\\test1.py"], stdout=subprocess.PIPE)
process.wait()
print process.returncode
在Windows命令提示符下,当我运行脚本时,我得到以下输出:
>python test1.py
>
>echo %errorlevel%
>24
>
>python myscript1.py
>24
因此,您可以看到子进程能够在这种情况下获得正确的退出代码.
在案例2中,我运行批处理文件test2.cmd.
test2.cmd
EXIT /B 56 <--exit code
myscript2.py
import subprocess
process = subprocess.Popen(["C:\\path\\to\\test2.cmd"], stdout=subprocess.PIPE)
process.wait()
print process.returncode
在Windows命令提示符下,当我运行脚本时,我得到以下输出:
>test2.cmd
>
>echo %errorlevel%
>56
>
>python myscript2.py
>56
因此,您可以看到子进程在这种情况下也能够获得正确的退出代码.
在案例3中,我运行了一个SikuliX脚本.
test3.sikuli
xxx xxx (sikuli script here)
xxx xxx
...
exit(16) <--exit code
myscript3.py
import subprocess
process = subprocess.Popen(["C:\\path\\to\\runsikuli.cmd", "-r", "C:\\path\\to\\sikuli-script.sikuli"], stdout=subprocess.PIPE)
process.wait()
print process.returncode
在Windows命令提示符下,当我运行脚本时,我得到以下输出:
>C:\path\to\runsikuli.cmd -r C:\path\to\sikuli-script.sikuli
>... (stdout + stderr)
>16
>
>echo %errorlevel%
>16
>
>python myscript3.py
>0
在案例3中,当我在命令提示符中手动运行脚本时,它可以设置%errorlevel%.当我使用Python子进程运行脚本时,子进程无法获取正确的退出代码.它总是返回0.
为什么Python子进程无法获取案例3中的退出代码?
解决方法:
如果运行相同的命令,则为your comment says,则命令提示符和使用Python子进程模块都会产生相同的结果(0退出代码).
您可能会看到不同的退出代码,因为您使用不同的命令这里不足为奇. Python子进程模块返回正确的(对于给定的命令)退出代码.
如果它没有返回正确的退出状态,那么你可以添加&在cmd.exe命令末尾退出,作为获取正确返回码的变通方法,请参阅Python问题跟踪器上的“subprocess on Windows: wrong return code with shell=True”:
from subprocess import check_call
check_call(r'C:\path\to\runsikuli.cmd -r C:\path\to\sikuli-script.sikuli & exit',
shell=True)
标签:python,subprocess,windows,jython,sikuli 来源: https://codeday.me/bug/20190629/1321201.html