1

看看下面的方法:

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

问题:尽管文件中的每一行都不同,但 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
4

1 回答 1

5

在您的类定义中,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 的对象模型、属性查找规则等。

于 2012-07-04T15:15:04.067 回答