0

0

Python 脚本如何正确返回退出码

冷漠man

冷漠man

发布时间:2026-01-30 18:52:52

|

746人浏览过

|

来源于php中文网

原创

sys.exit() 是最直接的Python脚本退出方式,参数决定退出码:0表示成功,非零表示失败;传字符串会打印到stderr且退出码为1;需避免os._exit(),异常未捕获时默认退出码为1。

python 脚本如何正确返回退出码

sys.exit() 是最直接的方式

Python 脚本的退出码由 sys.exit() 的参数决定,它会立即终止程序并把整数参数作为进程退出状态返回给 shell。不传参默认是 0(成功),传非零值(如 1、2)通常表示失败。

  • sys.exit(0) 表示正常结束,shell 中 $? 会得到 0
  • sys.exit(1) 是最常用的错误码,但语义需自行约定(比如参数错误、IO 失败等)
  • 传字符串(如 sys.exit("error"))会触发 SystemExit 异常并打印该字符串到 stderr,退出码仍为 1
  • 避免用 os._exit(),它绕过清理逻辑(如 atexit 注册函数、文件缓冲区刷新),仅在 fork 后子进程里必要时使用

异常未捕获时也会产生退出码

未被 try/except 捕获的异常会让 Python 解释器打印 traceback 并以退出码 1 结束进程。这看似“自动”,但实际不可控——你无法区分是 ValueError 还是 FileNotFoundError 导致的失败。

  • 显式捕获异常后调用 sys.exit(2) 或其他有意义的码,比放任崩溃更利于调试和自动化调用
  • 某些 CI 工具或 shell 脚本依赖特定退出码做分支判断(比如 126 表示命令不可执行,127 表示命令未找到),随意抛异常会丢失这个信号
  • 自定义异常类本身不改变退出行为,仍需配合 sys.exit() 才能设定非 1 的码

main() 函数返回值不会变成退出码

这是常见误解:写一个 def main(): return 42 然后调用它,脚本依然以 0 退出。Python 不像 C,main() 的返回值只是普通函数返回值,对进程状态无影响。

Tome
Tome

先进的AI智能PPT制作工具

下载
  • 必须显式调用 sys.exit(),或让异常传播到底层(但如前所述,不推荐)
  • 常见模式是:if __name__ == "__main__": sys.exit(main()),此时 main() 可以返回整数退出码,再由 sys.exit() 透出
  • 注意:如果 main() 返回 Nonesys.exit(None) 等价于 sys.exit(0)

Shell 层面验证退出码是否生效

写完脚本别只靠 print 看输出,得真正在 shell 里检查 $?。尤其当脚本被管道、后台运行或集成进 Makefile 时,退出码才是唯一可靠的信号。

立即学习Python免费学习笔记(深入)”;

  • 运行后立刻执行 echo $?,确认是否得到预期数字
  • set -e 的 shell 脚本中,任何非零退出都会中断执行,这时错设退出码可能导致误中断
  • 某些容器环境(如 Kubernetes initContainer)会严格检查退出码 0/非0 来判定就绪,返回错码可能让服务卡在启动阶段
真正难的不是怎么设退出码,而是统一设计一套内部可读、外部可解析的码表,并在所有异常路径里一致应用。没人会记住 7 和 13 分别代表什么,但文档里写清楚 2 = missing config file,再配个 EXIT_MISSING_CONFIG = 2 常量,就少很多半夜查日志的时刻。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
python中print函数的用法
python中print函数的用法

python中print函数的语法是“print(value1, value2, ..., sep=' ', end=' ', file=sys.stdout, flush=False)”。本专题为大家提供print相关的文章、下载、课程内容,供大家免费下载体验。

186

2023.09.27

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1502

2023.10.24

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

779

2023.08.22

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

228

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

297

2023.10.25

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

320

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1502

2023.10.24

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

9

2026.01.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.4万人学习

Django 教程
Django 教程

共28课时 | 3.7万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号