我试图写一个程序,其中包含一个类称为复合。这个类的一个基本形式是这里
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.components的值。我不知道为什么会这样。据我所见,如果其他值(例如name)没有更改,则意味着它在find\u components()部分中。然而,考虑到find\u的组成部分没有使用任何外部变量,我不明白为什么会发生这种情况
有人能解释一下这个问题吗?谢谢
constituents
的默认值[]
在所有对构造函数的调用中共享。我建议在将constituents
分配给self
时复制列表:这样你就安全了,不管发生什么事
相关问题 更多 >
编程相关推荐