程序中的日志打印,或者消息上传,比如kafka消息等等。经常上传的消息中需要上传堆栈信息中的文件名、行号、上层调用者等具体用于定位的消息。Python提供了以下两种方法:
sys._getframe
, 基础方法inspect.currentframe
, 推荐方法,提供除了sys._getframe
方法之外更多的frame相关的方法
具体使用如下
使用sys._getframe
私有方法
具体使用方法如下:
具体的函数输出结果演示可以参见下面的inspect模块结果
使用inspect
模块(推荐)
相比于sys的内置私有方法,更推荐inspect模块。inspect模块的具体使用方法如下
主要依赖inspect.currentframe方法,关于inspect.currentframe方法的使用见帮助文档
从调用堆栈返回一个帧对象。深度为整数,默认为0,返回调用堆栈顶部的帧。如果指定深度比调用堆栈深,会抛出ValueError异常。该功能应该只用于内部和专业目的。
inspect.currentframe方法的实现见内置库inspect.py
所以本质上inspect.currentframe方法等同于sys._getframe方法
currentframe = lambda _=None: None 等同于 currentframe = lambda _: None ,即lambda函数接收一个参数,返回None
参考:
Python frame hack
StackOverFlow-In Python, how do I obtain the current frame?