1

我正在从 dict 对象创建一个子类

class FeatureVector(dict):

    def __init__(self, init_val=0):
        super().__init__()
        self.init_val = init_val

在这个类中,我尝试使用字典理解自分配一个函数,如下面的简化示例:

    def load_fv(self, fvlist):
        self = {k:float(val) for k, val in fvlist}

在此示例中,fvlist 的构建方式如下:

fvlist = [["example", 1], ["feature", 2], ["vector", 3], ["list", 4]]

此 load_fv 方法不起作用。字典仍然是空的:{}

经过一番搜索,我发现这是因为self它是不可变的,如下所述:Why is `self` in Python objects immutable?

所以也许我只是想做一些我不应该做的事情。当然,有可能创建一个使用 for 循环执行 dict-comprehension 的函数:

    def load_fv(self, fvlist):
        self.clear()
        for x, y in fvlist:
            self[x] = y 

我仍然可以想象,如果字典已经可用,或者当我想用字典初始化类字典对象时,将字典“自分配”到 dict-child 类可能会更有效。

在那种情况下,我可以做类似的事情:

    def __init__(self, init_dict, init_val=0):
        super().__init__()
        self.init_val = init_val
        self.load_fv(fvlist)

    def load_fv(self, fvlist):
        self.clear()
        if isinstance(fvlist, dict) or isinstance(fvlist, FeatureVector):
            fvlist = [[key, val] for key, val in fvdict.items()]
        for x, y in fvlist:
            self[x] = y 

但这并没有真正让人感觉优雅和谨慎。有没有更好的单行/不那么冗长的方式?

4

1 回答 1

2

你试过这个吗?

def __init__(self, init_dict, init_val=0):
    super().__init__()
    self.init_val = init_val
    self.update(init_dict)
    # Here init_dict is a dictionary or a dictionary like object

update方法添加提供给自身的字典。

于 2015-01-19T22:33:27.090 回答