(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("发生异常")

相关推荐
MY_TEUCK6 小时前
【Java 后端】SpringBoot 登录认证与会话跟踪实战(JWT + Filter/Interceptor)
java·开发语言·spring boot
QQ2422199796 小时前
基于python+微信小程序的家教管理系统_mh3j9
开发语言·python·微信小程序
沐知全栈开发6 小时前
JavaScript 条件语句
开发语言
RSTJ_16256 小时前
PYTHON+AI LLM DAY THREETY-SEVEN
开发语言·人工智能·python
郝学胜-神的一滴6 小时前
深度学习优化核心:梯度下降与网络训练全解析
数据结构·人工智能·python·深度学习·算法·机器学习
Aision_7 小时前
Agent 为什么需要 Checkpoint?
人工智能·python·gpt·langchain·prompt·aigc·agi
清水白石0087 小时前
《Python性能深潜:从对象分配开销到“小对象风暴”的破解之道(含实战与最佳实践)》
开发语言·python
Je1lyfish7 小时前
CMU15-445 (2025 Fall/2026 Spring) Project#3 - QueryExecution
linux·c语言·开发语言·数据结构·数据库·c++·算法
Brilliantwxx7 小时前
【C++】 vector(代码实现+坑点讲解)
开发语言·c++·笔记·算法
野生技术架构师7 小时前
2026年最全Java面试题及答案汇总(建议收藏,面试前看这篇就够了)
java·开发语言·面试