如何检测dict修改?

时间:2015-12-20 11:11:37

标签: python dictionary

我已将dict子类化,并需要检测其所有修改。

(我知道我无法检测到存储值的就地修改。没关系。)

我的代码:

def __setitem__(self, key, value):
    super().__setitem__(key, value)
    self.modified = True

def __delitem__(self, key):
    super().__delitem__(key)
    self.modified = True

问题是它只适用于简单的分配或删除。它不会检测pop()popitem()clear()update()所做的更改。

为什么在添加或删除项目时会绕过__setitem____delitem__?我是否还必须重新定义所有这些方法(pop等)?

2 个答案:

答案 0 :(得分:6)

对于这种用法,你不应该继承dict类,而是使用Python标准库的collections模块中的抽象类。

您应该对MutableMapping抽象类进行子类化并覆盖以下方法:__getitem____setitem____delitem____iter____len__, 所有那些通过使用内部字典。抽象基类确保所有其他方法都使用这些方法。

class MyDict(collections.MutableMapping):
    def __init__(self):
        self.d = {}
        # other initializations ...

    def __setitem__(self, key, value):
        self.d[key] = value
        self.modified = true
    ...

答案 1 :(得分:1)

pop, popitem, clear, update未通过__setitem____delitem__实施。

您还必须重新定义它们。

我可以建议看看OrderedDict的实现。