我正在尝试为给定的一组键创建一个有序的 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.. 所以这样做有点麻烦。我想知道这样做的更好方法..以及为什么会这样。
添加回答
举报
0/150
提交
取消