Python类不是不同的?

时间:2015-11-08 16:25:14

标签: python class

我正在尝试编写一个包含一个名为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不使用任何外部变量,我无法理解为什么会发生这种情况。

有人能解决这个问题吗?谢谢!

1 个答案:

答案 0 :(得分:2)

constituents的默认值[]在所有对构造函数的调用中共享。我建议您在将constituents分配给self时简单地复制列表:

self.constituents = constituents[:]

这样,无论传递什么,你都是安全的。