Python记录详细调用堆栈日志的方法
本文实例讲述了Python记录详细调用堆栈日志的方法。分享给大家供大家参考。具体实现方法如下:
importsys
importos
defdetailtrace(info):
retStr=""
curindex=0
f=sys._getframe()
f=f.f_back#firstframeisdetailtrace,ignoreit
whilehasattr(f,"f_code"):
co=f.f_code
retStr="%s(%s:%s)->"%(os.path.basename(co.co_filename),
co.co_name,
f.f_lineno)+retStr
f=f.f_back
printretStr+info
deffoo():
detailtrace("helloworld")
defbar():
foo()
defmain():
bar()
if__name__=="__main__":
main()
输出:
aaa1.py(<module>:27)->aaa1.py(main:24)->aaa1.py(bar:21)->aaa1.py(foo:18)->helloworld
希望本文所述对大家的Python程序设计有所帮助。