看一下下面的方法:

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对象模型,属性查找规则等的更多信息。

10-07 16:32
查看更多