我正在调试一些代码,我想知道什么时候访问某个特定的字典。实际上,它是一个子类dict
的类,实现了一些额外的功能。无论如何,我想要做的是自己创建dict
的子类,并添加override __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
子类,并更改了对超级构造函数的调用。尽管如此,似乎什么都没有发生。我认为我是聪明的,但我不知道我是否应该走一个不同的方向。
谢谢你的帮助!
发布于 2010-03-06 08:42:16
你正在做的事情应该是完全有效的。我测试了您的类,除了日志语句中缺少的左括号之外,它工作得很好。我能想到的只有两件事。首先,您的日志语句的输出设置是否正确?您可能需要在脚本的顶部放置一个logging.basicConfig(level=logging.DEBUG)
。
其次,__getitem__
和__setitem__
仅在[]
访问期间调用。因此,请确保仅通过d[key]
访问DictWatch
,而不是通过d.get()
和d.set()
发布于 2010-03-06 09:27:10
对dict
进行子类化时的另一个问题是,内置的__init__
不调用update
,内置的update
也不调用__setitem__
。因此,如果你想让所有的部分操作都通过你的__setitem__
函数,你应该确保你自己调用它:
class DictWatch(dict):
def __init__(self, *args, **kwargs):
self.update(*args, **kwargs)
def __getitem__(self, key):
val = dict.__getitem__(self, key)
print('GET', key)
return val
def __setitem__(self, key, val):
print('SET', key, val)
dict.__setitem__(self, key, val)
def __repr__(self):
dictrepr = dict.__repr__(self)
return '%s(%s)' % (type(self).__name__, dictrepr)
def update(self, *args, **kwargs):
print('update', args, kwargs)
for k, v in dict(*args, **kwargs).iteritems():
self[k] = v
https://stackoverflow.com/questions/2390827
复制相似问题