Python 如何打印完整调用栈?

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() 返回一个带换行符的字符串,可直接保存或进一步处理。

多墨智能

多墨智能

多墨智能 – AI 驱动的创意工作流写作工具

下载

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

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

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

https://www.php.cn/faq/2019218.html

发表回复

Your email address will not be published. Required fields are marked *