系统相关
首页 > 系统相关> > 为什么有时Python子进程在运行进程后无法获得正确的退出代码?

为什么有时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