我生成了一个包含嵌套dataclass
的python dataclass
的两个不同实例。当我在一个实例中(但不在另一个实例中)更新嵌套dataclass
中的值时,相同的数据会在两个实例中都放在嵌套dataclass
中。这不是我所期望的。
from dataclasses import dataclass
@dataclass
class sub1:
q: int = 10
r: str = "qrst"
@dataclass
class A:
a: int = 1
s1: sub1 = sub1()
if __name__ == '__main__':
a = A()
aa = A()
aa.a = 9
aa.s1.r = "92"
print("a:", repr(a))
print("aa:", repr(aa))
''' Produces --
a: A(a=1, s1=sub1(q=10, r='92'))
aa: A(a=9, s1=sub1(q=10, r='92'))
'''
我希望嵌套的dataclass
仅在指定的实例(aa
)中更新,而嵌套的dataclass
在其他实例(a
)中保持不变
我在做什么错,还是dataclass
是错误的工具?
我拒绝将感谢视为绒毛。感谢所有回答的人,也感谢所有尝试删除它的人。
答案 0 :(得分:2)
您当前正在为该字段提供默认值。由于该值是一个可变对象,因此对该对象的更改将对您的数据类的所有实例都是可见的。
您应该做的是提供一个default factory,它为每个新的sub1
实例生成A
个实例:
from dataclasses import field
@dataclass
class A:
a: int = 1
s1: sub1 = field(default_factory=sub1)
a = A()
aa = A()
aa.a = 9
aa.s1.r = "92"
print("a:", repr(a)) # a: A(a=1, s1=sub1(q=10, r='qrst'))
print("aa:", repr(aa)) # aa: A(a=9, s1=sub1(q=10, r='92'))