获取函数的原始定义模块
问题描述
给定一个类或函数,有没有办法找到最初定义它的模块的完整路径?(即使用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__的函数。
相关文章