首页 > 编程语言 > 详细

python 获取调用栈和行号

时间:2020-04-24 00:33:58      阅读:119      评论:0      收藏:0      [点我收藏+]
# coding=utf-8
import sys


# noinspection PyProtectedMember,PyBroadException,SpellCheckingInspection
def f3():
    DEBUG_TRACE_LEVEL = 0

    # sys._getframe(0) 和 sys._getframe() 结果一样
    #
    # sys._getframe(0) 代表当前文件名,函数名,行号
    # sys._getframe(1) 代表上一层调用的文件名,函数名,行号,以此类推
    print(sys._getframe(DEBUG_TRACE_LEVEL).f_code.co_filename)
    print(sys._getframe(DEBUG_TRACE_LEVEL).f_code.co_name)
    print(sys._getframe(DEBUG_TRACE_LEVEL).f_lineno)

    try:
        raise Exception
    except Exception:
        # 也可以通过异常获取栈信息
        # tb_frame 代表当前栈信息,tb_frame.f_back 代表上一层调用栈信息,tb_frame.f_back.f_back 代表上上层调用,以此类推
        trace = sys.exc_info()[2].tb_frame
        for _ in range(DEBUG_TRACE_LEVEL):
            trace = trace.f_back

        print(trace.f_code.co_filename)
        print(trace.f_code.co_name)
        print(trace.f_lineno)


def f2():
    f3()


def f1():
    f2()


f1()




python 获取调用栈和行号

原文:https://www.cnblogs.com/moonlight-lin/p/12764603.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!