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

相关推荐
威联通网络存储2 小时前
某高端显示面板制造企业:基于威联通 TS-h2490FU 的 AOI 检测数据治理实践
python·制造
globaldomain5 小时前
什么是用于长距离高速传输的TCP窗口扩展?
开发语言·网络·php
沈阳信息学奥赛培训5 小时前
#undef 指令 (C/C++)
c语言·开发语言·c++
2401_873204655 小时前
分布式系统安全通信
开发语言·c++·算法
FreakStudio6 小时前
不用装软件!这款MicroPython浏览器 IDE :让你在手机上也能调试树莓派 Pico
python·单片机·嵌入式·电子diy·tinyml
m0_743470376 小时前
使用Python进行PDF文件的处理与操作
jvm·数据库·python
Dxy12393102166 小时前
JS发送请求的方法详解
开发语言·javascript·ecmascript
sw1213897 小时前
C++中的代理模式实战
开发语言·c++·算法
難釋懷7 小时前
Lua语法入门-条件控制、函数
开发语言·junit·lua
桌面运维家7 小时前
Win10打印机共享故障排查:权限与网络配置详解
开发语言·网络·php