我不知道为什么这样不行:
我正在使用PEP 372中的odict类,但我想将其用作__dict__
成员,即:
class Bag(object):
def __init__(self):
self.__dict__ = odict()
但不知为什么我得到了奇怪的结果。这是有效的:
>>> b = Bag()
>>> b.apple = 1
>>> b.apple
1
>>> b.banana = 2
>>> b.banana
2
但是试图访问实际的字典是行不通的:
>>> b.__dict__.items()
[]
>>> b.__dict__
odict.odict([])
更奇怪的是:
>>> b.__dict__['tomato'] = 3
>>> b.tomato
3
>>> b.__dict__
odict.odict([('tomato', 3)])
我觉得自己很蠢。你能帮我吗?
我能找到的最接近你问题的答案是http://mail.python.org/pipermail/python-bugs-list/2006-April/033155.html。
基本上,如果
__dict__
不是实际的dict()
,那么它将被忽略,并且属性查找将失败。另一种方法是使用odct作为成员,并相应地重写getitem和setitem方法。
如果您正在寻找一个具有OrderedDict属性访问权限的库,orderedattrdict包提供了这个功能。
披露:我是这个图书馆的作者。我想这可能会对未来的搜索者有所帮助。
西科拉的答案都是正确的。下面是一个更新的解决方案,有以下改进:
a.__dict__
的特殊情况下也可以工作copy.copy()
==
和!=
运算符。。。
相关问题 更多 >
编程相关推荐