sys._getframe()得到如下对象:
typedef struct _frame {
PyObject_VAR_HEAD
struct _frame *f_back; /* 调用者的帧 */
PyCodeObject *f_code; /* 帧对应的字节码对象 */
PyObject *f_builtins; /* 内置名字空间 */
PyObject *f_globals; /* 全局名字空间 */
PyObject *f_locals; /* 本地名字空间 */
PyObject **f_valuestack; /* 运行时栈底 */
PyObject **f_stacktop; /* 运行时栈顶 */
…….
}
重新定义如下打印函数:
def zlog(msg):
print '[file:%s] [func:%s] [line:%s] %s' % (sys._getframe().f_back.f_code.co_filename, sys._getframe().f_back.f_code.co_name, sys._getframe().f_back.f_lineno,msg)
得到如下效果:
本文详细介绍了Python中sys._getframe()函数的使用方法及其返回的帧对象结构。通过一个自定义的日志打印函数示例,展示了如何利用该函数获取当前函数调用堆栈的信息,包括文件名、函数名及行号。
3267

被折叠的 条评论
为什么被折叠?



