我已经在互联网上搜索了它,但到目前为止我找不到答案。
我有一个在其他文件中导入的库。假设该库是import my_lib
在使用它的文件中导入的。
在 mylib 中,我想做类似的事情,__imported_from__这样代码就知道导入的来源。我需要这个用于记录目的(不同的调用不同的日志文件/日志名)
这将是此刻的日志:
2018-09-13 01:36:00,921 - my_lib - INFO - Start Processing
2018-09-13 01:36:30,921 - my_lib - INFO - Done Processing
2018-09-13 01:37:00,921 - my_lib - INFO - Start Processing
2018-09-13 01:37:30,921 - my_lib - INFO - Done Processing
我希望 my_lib 包含导入文件中的名称,以便可以在我的日志记录中查看调用的来源。就像下面的例子
2018-09-13 01:36:00,921 - import_from_file_1 - INFO - Start Processing
2018-09-13 01:36:30,921 - import_from_file_1 - INFO - Done Processing
2018-09-13 01:37:00,921 - import_from_file_2 - INFO - Start Processing
2018-09-13 01:37:30,921 - import_from_file_2 - INFO - Done Processing
根据答案,我写了两行,为我提供了我想要的数据:
import inspect
from os.path import basename, splitext
imported_from_file = (inspect.stack()[1][1]) if __name__ != '__main__' else False
used_from = splitext(basename(imported_from_file))[0] if imported_from_file else __name__