2015-07-10 106 views
1

我想将一个列表定义为类内的实例变量,但它充当类变量。Python类实例与类变量

class THING: 
    def __init__(self, name, stuff): 
     self.name = name 
     self.dict = [] 
     for item in stuff: 
      self.dict.append(item) 

    def getname(self): 
     return self.name 

    def getlist(self): 
     return self.dict 

    def inc_datecnt(self,date): 
     for item in self.dict: 
      if item.has_key(date): 
       item[date] += 1 



list = [] 
dates=['July1,2015', 'July2,2015', 'July3,2015'] 
datecnts = [] 
for date in dates: 
    datecnts.append({date : 0}) 

list.append(THING('A', datecnts)) 
list.append(THING('B', datecnts)) 


for item in list: 
    print "\n", item.getname() 
    item.inc_datecnt('July1,2015') 
    for subitem in item.getlist(): 
     print subitem 

当我执行此我得到:

A 
{'July1,2015': 1} 
{'July2,2015': 0} 
{'July3,2015': 0} 

B 
{'July1,2015': 2} 
{'July2,2015': 0} 
{'July3,2015': 0} 

我似乎增加一个类字典元素July1,2015当我想(和期望)是增加一个实例变量。

帮助

+1

你重用'datecnts'构建THING'的'的两个实例,并且当你创建了一个新的列表中的'dict'内两者之间的相同。 – metatoaster

+0

也许你可以打印类型(项目),以确保对象是THING,而不是dict – ytpillai

+0

Python并不完全有办法打印出来,所以如果你需要做一个'def __str __(self)'只想打印出变量 – ytpillai

回答

1

你逝去的datecnts列表您THING对象的构造函数,你只是路过的参考值(和列表是可变的,字典是可变的),因此,如果您对字典的任何更改为A THING对象,它会反映在B,因为B也有同样的参考。您应该尝试执行datecntscopy.deepcopy,并将其分别发送至AB

示例 -

import copy 
list.append(THING('A', copy.deepcopy(datecnts))) 
list.append(THING('B', copy.deepcopy(datecnts))) 
+0

ahhhhh ....现在我明白了。 –

+1

请记住接受答案,如果有帮助的话,这对社区会有帮助。 –

+0

接受答案是单击左侧的刻度线。 –