给定一个类或函数,有没有办法找到最初定义它的模块的完整路径? (即使用def xxx
或class xxx
。)
我知道有sys.modules[func.__module__]
。但是,如果在包func
中导入__init__.py
,那么sys.modules
将只重定向到__init__.py
,因为该函数已被带入该命名空间,就我而言理解是。
一个具体的例子:
>>> import numpy as np
>>> import sys
>>> np.broadcast.__module__
'numpy'
>>> sys.modules[np.broadcast.__module__]
<module 'numpy' from '/Users/brad/.../site-packages/numpy/__init__.py'>
显然,broadcast
中没有定义__init__.py
;它只是使用these from module import *
语句之一进入命名空间。
很高兴看到源np.broadcast
中的位置被定义(无论文件扩展名是什么,不管是.c还是.py)。这可能吗?
答案 0 :(得分:2)
您的理解:
但是,如果在包
func
中导入__init__.py
,那么sys.modules
只会重定向到__init__.py
,因为 函数已被带入该命名空间,就我而言 理解是。
错了。 __init__.py
导入某个内容对该内容的__module__
没有任何影响。
你在numpy.broadcast
看到的行为是因为C类型实际上没有“定义模块”,就像用Python编写的类型一样。 numpy.broadcast.__module__ == 'numpy'
因为numpy.broadcast
是written in C并声明其名称为"numpy.broadcast"
,而C类型__module__
是根据其名称确定的。{/ p>
至于如何获得一个类或函数的“原始定义模块”,你真正拥有的最好的是__module__
和其他通过__module__
的函数。