Python 如何打印完整调用栈?

9次阅读

traceback.print_exc()可直接打印当前异常完整调用;format_exc()返回字符串用于日志;print_stack()显示无异常时的调用链;底层可用print_exception()等精细控制。

Python 如何打印完整调用栈?

直接用 traceback.print_exc() 就能打印当前异常的完整调用,包括文件名、行号和函数名。

捕获异常后打印完整堆栈

try...except 中,不手动抛出异常时,用 traceback.print_exc() 最简洁:

import traceback  try:     1 / 0 except ZeroDivisionError:     traceback.print_exc()

它会输出从异常发生点到最外层调用的全部帧,比只打印 str(e)repr(e) 信息更全。

获取堆栈字符串而非直接打印

如果需要把堆栈存成字符串(比如写日志),用 traceback.format_exc()

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

import traceback  try:     raise ValueError("出错了") except ValueError as e:     stack_str = traceback.format_exc()     print("记录日志:", stack_str[:200] + "...")

format_exc() 返回一个带换行符的字符串,可直接保存或进一步处理。

手动触发并打印任意位置的调用栈

即使没发生异常,也能查看当前执行位置的“活堆栈”:

import traceback import sys  def a(): b() def b(): c() def c(): traceback.print_stack()  a()

这时输出的是从 c() 向上追溯到入口的调用链,不含异常信息,适合调试流程卡点。

更精细控制:指定异常对象和回溯对象

在底层异常处理或框架中,有时需显式传入 exc_info

  • traceback.print_exception(*sys.exc_info()) —— 等价于 print_exc()
  • traceback.print_tb(sys.exc_info()[2]) —— 只打印 traceback 部分(不含异常类型和值)
  • traceback.print_exception(etype, value, tb, limit=5) —— 可限制显示层数

一般情况用 print_exc()format_exc() 足够,复杂场景再考虑这些细粒度接口

text=ZqhQzanResources