1. 程式人生 > >python 列印呼叫函式名和檔名

python 列印呼叫函式名和檔名

import inspect
import sys

def get_current_function_name():
funcName = sys._getframe().f_back.f_code.co_name # 獲取呼叫函式名
print(dir(sys._getframe()))
print(dir(sys._getframe().f_back.f_code.co_filename))
print(sys._getframe().f_back.f_code.co_filename,"#",name,"#",file) #列印呼叫該函式 語句所在檔案和 列印該函式所在模組和列印該函式所在檔名
#E:/project/script/testmodule/test04.py # script.testmodule.test05 # E:\project\script\testmodule\test05.py
print(sys._getframe().f_back.f_code.co_names) #('unittest', 'chardet', 'script.testmodule', 'test05', 'get_current_function_name')
lineNumber = sys._getframe().f_back.f_lineno # 獲取行號

print(sys._getframe().f_code.co_name,"#########")  # 獲取當前函式名
print(funcName,lineNumber)
print("####%s.%s invoked" % (__name__, inspect.stack()))
return inspect.stack()[1][3]

class MyClass:
def function_one(self):
print("%s.%s invoked"%(self.__class__.__name__, get_current_function_name()))
if name

== "main":
myclass = MyClass()
myclass.function_one()
print(sys._getframe().f_code.co_filename)