我正在从 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
但这并没有真正让人感觉优雅和谨慎。有没有更好的单行/不那么冗长的方式?