获取函数的原始定义模块
问题描述
给定一个类或函数,有没有办法找到最初定义它的模块的完整路径?(即使用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
中定义的;它只是通过thesefrom module import *
语句之一引入到命名空间中。
np.broadcast
在源代码中的定义位置(不管文件扩展名是.c还是.py)。这可能吗?
解决方案
您的理解:
但是,如果在包的__init__.py
中导入func
,则sys.modules
将直接重定向到__init__.py
,因为 函数已被引入到该命名空间中,就我的 理解去了。
是错误的。__init__.py
导入对象不会影响该对象的__module__
。
您在numpy.broadcast
中看到的行为之所以会发生,是因为C类型并不像在Python中编写的类型那样具有真正的"定义模块"。numpy.broadcast.__module__ == 'numpy'
因为numpy.broadcast
为written in C并声明其名称为"numpy.broadcast"
,而C类型的__module__
由其名称确定。
至于如何获取一个类或函数的"原始定义模块",最好的就是__module__
和其他经过__module__
的函数。
相关文章