如何正确地将dict子类化并覆盖__getitem__和__setitem__

问题描述

您正在做的事情绝对应该有效。我测试了您的类,除了在日志语句中缺少左括号之外,它还可以正常工作。我只能想到两件事。首先,您的log语句的输出设置正确吗?您可能需要logging.basicConfig(level=logging.DEBUG)在脚本的顶部放置一个。

其次,__getitem____setitem__只在所谓的[]访问。因此,请确保您仅DictWatch通过d[key]而不是d.get()和访问d.set()

解决方法

我正在调试一些代码,我想找出何时访问特定词典。好吧,它实际上是一个子类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,str(val)))
        dict.__setitem__(self,val)

name_label'是最终要设置的键,我想用它来识别输出。然后,我将要检测的类更改为子类,DictWatch而不是子类,dict并更改了对超级构造函数的调用。不过,似乎什么都没有发生。我以为自己很聪明,但是我想知道我是否应该朝另一个方向发展。

谢谢您的帮助!

猜你在找的技术问答相关文章

如何检查配对的蓝牙设备是打印机还是扫描仪(Android)
是否允许实体正文进行HTTP DELETE请求?
如何将ZipInputStream转换为InputStream?
java.util.logging Java 8中的变量
PowerMockito.doReturn返回null
Java中的RESTful调用
Swing / Java:如何正确使用getText和setText字符串
特殊字符和重音字符
Android Studio中的ndk.dir错误
错误“找不到主类”