您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

异常中的堆栈跟踪中的locals()和globals()(Python)

异常中的堆栈跟踪中的locals()和globals()(Python)

您可以安装自己的异常挂钩,并从那里输出所需的内容

import sys, traceback

def excepthook(type, value, tb):
    traceback.print_exception(type, value, tb)

    while tb.tb_next:
        tb = tb.tb_next

    print >>sys.stderr, 'Locals:',  tb.tb_frame.f_locals
    print >>sys.stderr, 'Globals:', tb.tb_frame.f_globals

sys.excepthook = excepthook

def x():
    y()

def y():
    foo = 1
    bar = 0

    foo/bar

x()

要在回溯中从 每个 帧打印var ,请将上述循环更改为

    while tb:
        print >>sys.stderr, 'Locals:',  tb.tb_frame.f_locals
        print >>sys.stderr, 'Globals:', tb.tb_frame.f_globals
        tb = tb.tb_next
python 2022/1/1 18:33:51 有214人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶