请看以下方法:
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
问题是:尽管文件中的每一行都不相同,但adu mediums字典中的值却完全相同。在我看来,好像创建一个新对象“ad\u medium=Objects.Ad\介质()”没有效果,只是简单地覆盖上一个循环的对象中的值。你知道吗
我怎样才能解决这个问题?你知道吗
编辑:广告大学中级班
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、categories和impression是类属性(由所有实例共享)。
ad_medium.id = int( parts[0] )
语句定义了一个'id'实例属性,但是对categories和impression的所有操作(不是反弹而是变异的)都对class属性起作用。您希望类定义有一个初始值设定项方法,在其中创建实例属性,即:我强烈建议您进一步了解Python的对象模型、属性查找规则等
相关问题 更多 >
编程相关推荐