有时候打印调试信息时,希望获取当前文件名,有几种方法:

一、获取当前文件名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

  1. cur_frame = sys._getframe()
  2. cur_filename = os.path.basename(cur_frame.f_code.co_filename)
  3. cur_funcname = cur_frame.f_code.co_name
  4. cur_lineno = cur_frame.f_lineno
  5. print(cur_filename)
  6. print(cur_funcname)
  7. print(cur_lineno)

2.获取调用者所在文件的frame

  1. back_frame = sys._getframe().f_back
  2. back_filename = os.path.basename(back_frame.f_code.co_filename)
  3. back_funcname = back_frame.f_code.co_name
  4. back_lineno = back_frame.f_lineno
  5. print(back_filename)
  6. print(back_funcname)
  7. print(back_lineno)

好了,不管是当前文件还是调用者文件信息都能获取,且调用者可以不断的back逆推,根据业务需要而定。

https://www.jianshu.com/p/f5cc3002255b