最佳答案
我正在调试一些代码,我想知道什么时候访问一个特定的字典。实际上,它是一个子类 dict
的类,实现了一些额外的特性。无论如何,我想做的是子类 dict
自己并添加覆盖 __getitem__
和 __setitem__
产生一些调试输出。现在,我有
class DictWatch(dict):
def __init__(self, *args):
dict.__init__(self, args)
def __getitem__(self, key):
val = dict.__getitem__(self, key)
log.info("GET %s['%s'] = %s" % str(dict.get(self, 'name_label')), str(key), str(val)))
return val
def __setitem__(self, key, val):
log.info("SET %s['%s'] = %s" % str(dict.get(self, 'name_label')), str(key), str(val)))
dict.__setitem__(self, key, val)
'name_label'
是一个最终将被设置的键,我想用它来标识输出。然后,我将要检测的类更改为子类 DictWatch
而不是 dict
,并更改了对超级构造函数的调用。不过,似乎什么也没有发生。我以为我很聪明,但我不知道我是否应该走一个不同的方向。
谢谢你的帮助!