Python属性更改侦听器模式

时间:2011-03-03 21:04:52

标签: python

任何人都知道在python中跟踪字典对象更改的任何简单方法吗?我处于一个很高的层次,所以我有几个方法来处理更改字典,如果字典改变我想调用一个函数来基本上做一个Observer / Notify。

 class MyClass(object):
     def update(self, item):
        changed = False

        if(self.my_dict.has_key(item.id)):
           self.my_dict[item.id] = item
           changed = True

        if(changed):
          self.notify()

我要避免的是所有跟踪(设置布尔值)代码。希望有一种更简单的方法来跟踪变化。这是一个简单的案例,但可能有更复杂的逻辑导致我必须设置更改的标志。

2 个答案:

答案 0 :(得分:12)

您可以从dict类派生,并在任何更改上添加回调。这需要覆盖任何更改字典的方法:

class NotifyDict(dict):
    __slots__ = ["callback"]
    def __init__(self, callback, *args, **kwargs):
        self.callback = callback
        dict.__init__(self, *args, **kwargs)
    def _wrap(method):
        def wrapper(self, *args, **kwargs):
            result = method(self, *args, **kwargs)
            self.callback()
            return result
        return wrapper
    __delitem__ = _wrap(dict.__delitem__)
    __setitem__ = _wrap(dict.__setitem__)
    clear = _wrap(dict.clear)
    pop = _wrap(dict.pop)
    popitem = _wrap(dict.popitem)
    setdefault = _wrap(dict.setdefault)
    update =  _wrap(dict.update)

答案 1 :(得分:0)

子类dict并覆盖__setitem__,确保在您的内容之后调用dict.__setitem__以确保该项目实际得到保存。

class Notifier(dict):
    def __setitem__(self, key, value):
        print 'Something is being set!'
        dict.__setitem__(self, key, value)