任何人都知道在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()
我要避免的是所有跟踪(设置布尔值)代码。希望有一种更简单的方法来跟踪变化。这是一个简单的案例,但可能有更复杂的逻辑导致我必须设置更改的标志。
答案 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)