我正在尝试为给定的一组键创建一个有序的 dic。我要去的结构是`
OrderedDict([('A', [0, 0, 0, 0, 0, 0, 0, 0, 0, 0]),
('B', [0, 0, 0, 0, 0, 0, 0, 0, 0, 0]),
('C', [0, 0, 0, 0, 0, 0, 0, 0, 0, 0]),
('D', [0, 0, 0, 0, 0, 0, 0, 0, 0, 0])])`
这是由以下函数创建的。
d = OrderedDict.fromkeys(keys, [0 for _ in range(10)])
我成功地获得了所需的结构。
问题是 dict 的所有值都被创建为引用。这意味着当我尝试执行以下操作时,d['A'][1] = "11111" 它会更改给定每个键的值。我得到如下结果。
OrderedDict([('A', [0, '11111', 0, 0, 0, 0, 0, 0, 0, 0]),
('B', [0, '11111', 0, 0, 0, 0, 0, 0, 0, 0]),
('C', [0, '11111', 0, 0, 0, 0, 0, 0, 0, 0]),
('D', [0, '11111', 0, 0, 0, 0, 0, 0, 0, 0])])
我确实尝试过 deepcopy 但并没有真正帮助。我目前的工作是
d['A'] = d['A'][:]
我不太喜欢上面的解决方案,因为我有大约6mil keys and values.. 所以这样做有点麻烦。
我想知道这样做的更好方法..以及为什么会这样。
收到一只叮咚
相关分类