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

直接用 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() 足够,复杂场景再考虑这些细粒度接口。











