(20)python开发经验 --- python捕获异常后显示栈信息


更多精彩内容
👉内容导航 👈
👉Qt开发 👈
👉python开发 👈

  • 捕获异常后,将栈信息打印或者输出到log,便于排查定位问题;
  • traceback.format_exc() 是 Python 标准库中用于格式化异常跟踪信息的重要函数。
  • 参数说明
    • limit (可选):

      • 指定返回的栈跟踪帧数
      • 默认为 None,表示返回完整的栈跟踪
      • 正数表示从最内层帧开始计算,负数表示从最外层帧开始计算
    • chain (可选):

      • 控制是否包含异常链信息
      • 默认为 True,会显示异常链
      • 设置为 False 时只显示当前异常
    • 返回值

    • 返回一个字符串,包含格式化的异常跟踪信息

    • 字符串格式与 traceback.print_exc() 打印的内容相同

python 复制代码
import traceback

def function_a():
    function_b()

def function_b():
    function_c()

def function_c():
    raise ValueError("这是一个测试异常")

try:
    function_a()
except ValueError as e:
    # 获取格式化的异常信息
    exc_info = traceback.format_exc()
    print("异常跟踪信息:")
    print(exc_info)
  • 使用logging也可以输出异常调用栈
    • logging.error("发生异常: %s", str(e), exc_info=True)
    • logging.exception("发生异常")

相关推荐
zone77391 天前
001:简单 RAG 入门
后端·python·面试
F_Quant1 天前
🚀 Python打包踩坑指南:彻底解决 Nuitka --onefile 配置文件丢失与重启报错问题
python·操作系统
允许部分打工人先富起来1 天前
在node项目中执行python脚本
前端·python·node.js
IVEN_1 天前
Python OpenCV: RGB三色识别的最佳工程实践
python·opencv
haosend1 天前
AI时代,传统网络运维人员的转型指南
python·数据网络·网络自动化
曲幽1 天前
不止于JWT:用FastAPI的Depends实现细粒度权限控制
python·fastapi·web·jwt·rbac·permission·depends·abac
IVEN_2 天前
只会Python皮毛?深入理解这几点,轻松进阶全栈开发
python·全栈
Ray Liang2 天前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
AI攻城狮2 天前
如何给 AI Agent 做"断舍离":OpenClaw Session 自动清理实践
python
千寻girling2 天前
一份不可多得的 《 Python 》语言教程
人工智能·后端·python