为什么有时Python子进程在运行进程后无法获得正确的退出代码?

2023-12-09

我正在使用 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.

测试2.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 script.

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中无法获取退出代码?


As 你的评论说如果你跑相同的命令然后命令提示符和使用Pythonsubprocess模块产生相同的结果(0 退出代码)。

您可能会看到不同的退出代码,因为您使用不同的命令。这里并不奇怪。 Pythonsubprocess模块返回正确的(对于给定命令)退出代码。


如果它没有返回正确的退出状态,那么您可以添加& exit在 cmd.exe 命令末尾作为获取正确返回代码的解决方法,请参阅“Windows 上的子进程:shell=True 时返回代码错误”关于 Python 问题跟踪器:

from subprocess import check_call

check_call(r'C:\path\to\runsikuli.cmd -r C:\path\to\sikuli-script.sikuli & exit',
           shell=True)
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

为什么有时Python子进程在运行进程后无法获得正确的退出代码? 的相关文章

随机推荐