【发布时间】:2011-05-24 20:38:45
【问题描述】:
__getattr__ 和__setattr__ 在我使用点符号获取或设置对象的属性时效果很好。
如何从模块内部拦截获取和设置模块全局变量?
I 子类化模块类型:
from types import ModuleType
class WUserModule(ModuleType):
def __init__(self, name):
super().__init__(name)
def __setattr__(self, name, value):
if name in self.__dict__:
super().__setattr__(name, value)
return
print('Set name {}, value {}'.format(name, str(value)))
def __getattr__(self, name):
print('Get name {}'.format(name))
创建一个空模块并将代码加载到其中:
module = WUserModule('form_module')
with open('user_module.py', 'r', encoding='utf8') as f:
exec(f.read(), module.__dict__)
从user_module.py加载的代码:
a=1
print(a)
我需要以某种方式拦截对变量a 的访问。在加载的代码中,预计会访问模块globals() 中不存在的一些变量,我想替换请求的值。
更新:
上面的代码不能按我的需要工作:print 没有反映对变量 a 的访问。
我正在使用 PyQt4 编写一个“平台”,其他用户(程序员)在其中添加处理与这些表单交互的表单和模块。表单本身可通过“注入”变量form 在用户模块中访问。我想让用户有可能从表单小部件和更简单的方式访问值。而不是写if form.myCheckbox.isChecked()或form.myCheckbox.setChecked(myValue)我想提供一个快捷方式:if myCheckbox和myCheckbox = myValue,拦截值访问并在后台进行所需的工作:
def __getattr__(self, name):
formWidget = getatttr(form, name)
if isinstance(formWidget, QLineEdit):
formWidget.setText(value)
...
【问题讨论】:
-
您的实际问题是什么,因为您似乎已经回答了“我如何从模块内部拦截获取和设置模块全局变量?”?