遍历所有值并找到该值的键

时间:2020-05-05 18:17:43

标签: python list python-2.7 dictionary python-3.3

我需要遍历字典并查找某些值的键。字典如下:

z1 = {9376: 172, 1: 168, 2: 179, 3: 2, 132: 9740, 145: 179, 137: 185, 135: 1, 142: 13528, 113: 158, 9781: 176, 9782: 168, 152: 13527, 9375: 9504, 127: 1}

也 我有一个清单,我想检查一下字典并找出相应的键。

z =[13527,9741,9740,9505,9504,200,189,185,176,172,168,1]

我需要找到z1中存在z中的哪些值,然后制作匹配值和key的字典。以下是我正在使用的代码

for i in range(len(z1)) :
    try :
        p = z[i]
        a = list(z1.keys())[list(z1.values()).index(p)]
        e1.append(a)
        e2.append(p)
    except (ValueError, IndexError,AttributeError) :
        continue
e3 = list(zip(e1,e2))
print(e3)

我得到的结果是

[(152, 13527), (132, 9740), (9375, 9504), (137, 185), (9781, 176), (9376, 172), (1, 168), (135, 1)]

现在在字典z1中,您可以看到值168,1重复了两次并具有唯一键。当我运行for循环时,我只会得到单个键值对。我应该怎么做才能使所有键具有相同的值。即我的最终答案应该是

[(152, 13527), (132, 9740), (9375, 9504), (137, 185), (9781, 176), (9376, 172), (1, 168), (9782,168) (135, 1), (127,1)]

2 个答案:

答案 0 :(得分:0)

也许这就是您所需要的:

e3 = [(k, i) for i in z for k in z1 if i==z1[k]]

给我:

[(152, 13527), (132, 9740), (9375, 9504), (137, 185), (9781, 176), (9376, 172), (1, 168), (9782, 168), (135, 1), (127, 1)]

答案 1 :(得分:0)

遍历字典的值会破坏首先使用字典的目的。

如果由于在某处使用而需要存储key, value,那么我还建议建立value, key的反向字典。

如果值不是唯一的,则建立一个像value, [list_of_keys]这样的字典。这种方法将更快。

每次对值的遍历将是O(n),但是建立反向字典将是O(1)。对于较大的n值,您的程序将运行得更快。