首页 > 解决方案 > 字典更新覆盖重复键

问题描述

我有一张表,其中有 6982 条记录,我正在阅读这些记录以制作字典。我使用文字来创建字典

fld_zone_dict = dict()
fields = ['uniqueid', 'FLD_ZONE', 'FLD_ZONE_1']
...
for row in cursor:
    uid = row[0]
    old_zone_value = row[1]
    new_zone_value = row[2]
    fld_zone_dict[uid] = [old_zone_value, new_zone_value]

但是,我注意到使用此方法时,如果 uid 具有与以前相同的值uid(理论上可能存在重复),则该条目将被覆盖。因此,如果我有 2 个要添加的条目:'CA10376036': ['AE', 'X']并且'CA10376036': ['V', 'D'],第一个被覆盖,我只得到 'CA10376036': ['V', 'D']. 如何在不覆盖重复键的情况下添加到我的字典中,以便得到类似的东西?

fld_zone_dict = {'CA10376036': ['AE', 'X'], 'CA9194089':['D', 'X'],'CA10376036': ['V', 'D']....} 

标签: listdictionarypython-3.6updates

解决方案


简短的回答:没有办法在 Python 中的字典对象中有重复的键。

但是,如果您要重组数据并获取该键并将其放入嵌套在列表中的字典中,则可能会有重复的 ID。前任:

[
    {
        "id": "CA10376036",
        "data: ['AE', 'X']
    },
    {
        "id": "CA10376036",
        "data: ['V', 'D']
    },
]

但是,这样做会否定查找速度和易用性的任何好处。

编辑:blhsing 也有一个很好的例子,说明如何通过减少初始查找时间来重组数据,尽管您仍然需要遍历数据以获得所需的记录。


推荐阅读