在 Python 中,对象可以具有未在其类定义中定义的动态属性。这种动态行为是通过 getattr 方法实现的,当对象的属性查找失败时会调用该方法。不幸的是,模块本身并不支持 __getattr__。
目标是模仿模块上的 getattr 功能,以便在找不到属性时,使用以下命令创建预定义类的实例相同的名称,并且在该实例上调用具有该名称的方法。
尝试在模块上实现getattr,如下所示:
<code class="python">class A(object): def salutation(self, accusative): print "hello", accusative # intentionally on the module, not the class def __getattr__(mod, name): return getattr(A(), name) if __name__ == "__main__": salutation("world") # hoping for __getattr__ to be invoked</code>
但是,这种方法遇到两个障碍:
包装方法:
sys.modules字典很灵活,允许创建拦截模块访问的包装器。但是,这仅支持通过模块访问方法,而不支持模块本身的访问方法。此外,与全局方法相比,每次创建一个新实例可能会导致不同的行为。
类替换:
根据 Guido van Rossum 的推荐,这是一种 hackish 方法涉及创建一个类并用该类的实例替换 sys.modules[__name__]。这使得可以使用 __getattr__/__setattr__/__getattribute__。不过,它也有一些警告:
虽然 Python 模块本身不支持 __getattr__,但建议的解决方案提供了解决方法来为模块实现类似的动态属性解析。
以上是如何在Python中实现模块的getattr功能?的详细内容。更多信息请关注PHP中文网其他相关文章!