我有相互继承的现有类...他们已经有一个属性在子类中被覆盖。我希望更新字典属性而不是覆盖...下面的代码...
class A:
d = {1:2}
class B(A):
d = {3:4}
b=B()
print b.d[1]
2
print b.d[3]
4
这可能吗?说以一种我无法轻易想到的方式使用元类。
class A(object):
d = {1:2}
class B(A):
d = {3:4}
def __init__(self):
dtemp = self.d
self.d = A.d.copy() # warning: shallow
self.d.update(dtemp)
b=B()
print b.d[1]
# 2
print b.d[3]
# 4
a=A()
print a.d[1]
# 2
print a.d[3]
# KeyError
不知道你到底想在这里做什么,但如果你在py3.3+上,看起来collections.ChainMap
可能会派上用场:
from collections import ChainMap
...
dic = ChainMap(B.d, A.d)
演示:
>>> dic[1]
2
>>> dic[3]
4
对A.d
或B.d
所做的任何修改都将反映在dic
>>> A.d[4] = 5
>>> dic[4]
5
修改字典本身将修改B.d
(传递给ChainMap
的第一个字典):
>>> dic[6] = 7
>>> B.d
{3: 4, 6: 7}
根据周围的一些想法找到了这一点:
B类(A): _d = {}
def __init__(self):
for parent_klass in inspect.getmro(self.__class__):
_d.update(getattr(parent_klass, 'd', {}))
_d.update(self.d)
self.d = _d