python 获取调用栈和行号
# 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
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?