如何正确地将dict子类化并覆盖__getitem__和__setitem__
我正在调试一些代码,我想找出何时访问特定词典。好吧,它实际上是一个子类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
并更改了对超级构造函数的调用。不过,似乎什么都没有发生。我以为自己很聪明,但是我想知道我是否应该朝另一个方向发展。
谢谢您的帮助!
回答:
您正在做的事情绝对应该有效。我测试了您的类,除了在日志语句中缺少左括号之外,它还可以正常工作。我只能想到两件事。首先,您的log语句的输出设置正确吗?您可能需要logging.basicConfig(level=logging.DEBUG)
在脚本的顶部放置一个。
其次,__getitem__
和__setitem__
只在所谓的[]
访问。因此,请确保您仅DictWatch
通过d[key]
而不是d.get()
和访问d.set()
以上是 如何正确地将dict子类化并覆盖__getitem__和__setitem__ 的全部内容, 来源链接: utcz.com/qa/399794.html