我正在尝试编写一个包含一个名为compound的类的程序。这个类的基本形式在这里;
class Compound:
def __init__(self, name="", entropy=0, enthalpy=0, constituents=[]):
self.constituents = constituents
self.name = name
self.entropy = entropy
self.enthalpy = enthalpy
self.check_data()
if (name != ""):
self.find_constituents()
def find_constituents(self):
name = self.name
if (len(name) == 0):
return 0
name = re.sub(r'\([a-z]+\)', '', name)
p = re.findall(r'\d+', name[0])
if (len(p) > 0):
name = name[1:]
lop = int(p[0])
else:
lop = 1
chem = re.findall('[A-Z][a-z0-9]{0,3}', name)
for p in chem:
l = re.findall(r'\d+', p)
if (len(l) == 1):
num = int(l[0])
else:
num = 1
q = re.sub(r'\d+', '', p)
print q
try:
for l in range(0, num):
for ki in range(0, lop):
self.constituents.append(q)
except:
print("Element "+q+" not found.")
从本质上讲,它所做的就是将名称作为输入,如果名称不是“”,那么它会尝试将其分解为组件并将它们放入组件中 - 因此,F2将[F,F]放入成分,NaOH会放[Na,O,H]等。
使用单个化合物运行时,它可以正常工作;
>>> a = Compound("F2")
Data not found
F
>>> print vars(a)
{'constituents': ['F', 'F'], 'entropy': 0, 'name': 'F2', 'enthalpy': 0}
当我再次运行时,但在打印之前,我将另一个变量b分配给另一个化合物;
>>> a = Compound("F2")
Data not found
F
>>> b = Compound("NaOH")
Data not found
Na
O
H
>>> print vars(a)
{'constituents': ['F', 'F', 'Na', 'O', 'H', 'F', 'F', 'Na', 'O', 'H'], 'entropy': 0, 'name': 'F2', 'enthalpy': 0}
由于某种原因,在此重新分配中改变了a.constituents的价值。我不知道为什么会这样。从我所看到的,鉴于其他值(例如名称)没有改变,它意味着它在find_constituents()部分内。然而,鉴于find_constituents不使用任何外部变量,我无法理解为什么会发生这种情况。
有人能解决这个问题吗?谢谢!
答案 0 :(得分:2)
constituents
的默认值[]
在所有对构造函数的调用中共享。我建议您在将constituents
分配给self
时简单地复制列表:
self.constituents = constituents[:]
这样,无论传递什么,你都是安全的。