看一下下面的方法:
def load_ad_mediums_from_file(self, filename ):
file = io.open( filename, "r" )
ad_mediums = {}
for line in file:
if len(line) > 0 and line[0] != 'a':
parts = line.strip().split(";")
ad_medium = Objects.Ad_Medium()
ad_medium.id = int( parts[0] )
for i in range(1,8):
cat_parts = parts[i].strip().split(",")
category_id = int(cat_parts[0]);
ad_medium.categories[category_id] = float(cat_parts[1])
ad_medium.impressions[category_id] = int(cat_parts[2])
ad_mediums.update( { ad_medium.id : ad_medium } )
file.close()
return ad_mediums
问题:Althoug文件中的每一行都是不同的,ad_mediums词典中的值具有相同的值。在我看来,创建新对象“ ad_medium = Objects.Ad_Medium()”似乎无效,而只是覆盖上一个循环的对象中的值。
我怎样才能解决这个问题?
编辑:Ad_Medium类
class Ad_Medium(object):
id = 0
categories = { 1:0.0, 2:0.0, 3:0.0, 4:0.0, 5:0.0, 6:0.0, 7:0.0 }
impressions = { 1:0, 2:0, 3:0, 4:0, 5:0, 6:0, 7:0 }
def __str__(self):
string = str(self.id) + ";"
for i in range(1,8):
string += str(i) + "," + str( self.categories[i] ) + "," + str( self.impressions[i] ) + ";"
return string[:-1] + "\n"
def normalize_categories_with_impressions(self ):
impressions = 0.0
for i in range(1,8):
impressions += float(self.impressions[i])
if impressions == 0.0:
return
for i in range(1,8):
self.categories[i] = float(self.categories[i])/float(impressions)
def reset_categories(self):
for i in range(1,8):
self.categories[i] = 0
最佳答案
在您的类定义中,id,类别和印象是类属性(由所有实例共享)。 ad_medium.id = int( parts[0] )
语句定义了一个'id'实例属性,但是对类别和印象的所有操作(不是反弹而是变异的)都在类属性上起作用。您希望您的类定义具有用于创建实例属性的初始化方法,即:
class Ad_Medium(object):
def __init__(self):
self.id = 0
self.categories = { 1:0.0, 2:0.0, 3:0.0, 4:0.0, 5:0.0, 6:0.0, 7:0.0 }
self.impressions = { 1:0, 2:0, 3:0, 4:0, 5:0, 6:0, 7:0 }
我强烈建议您了解有关Python对象模型,属性查找规则等的更多信息。