有时候打印调试信息时,希望获取当前文件名,有几种方法:
一、获取当前文件名3种方法
1.使用python文件默认的‘ file ’属性os.path.basename(__file__)
2.使用sys.argv[0]os.path.basename(sys.argv[0])
3.使用sys._getframe()os.path.basename(sys._getframe().f_back.f_code.co_filename)
二、获取上级(调用者)文件名方法
而有时候在封装log时,log.debug('this is msg')是在外部调用的,所以无法定位到具体输出最终lineno、function、filename,而这里刚好通过sys._getframe()来完成。
1.获取当前文件的frame
cur_frame = sys._getframe()cur_filename = os.path.basename(cur_frame.f_code.co_filename)cur_funcname = cur_frame.f_code.co_namecur_lineno = cur_frame.f_linenoprint(cur_filename)print(cur_funcname)print(cur_lineno)
2.获取调用者所在文件的frame
back_frame = sys._getframe().f_backback_filename = os.path.basename(back_frame.f_code.co_filename)back_funcname = back_frame.f_code.co_nameback_lineno = back_frame.f_linenoprint(back_filename)print(back_funcname)print(back_lineno)
好了,不管是当前文件还是调用者文件信息都能获取,且调用者可以不断的back逆推,根据业务需要而定。
