python如何删除dict中重复value值的item

字典 z 如下

z = {
    1: 'a',
    2: 'a',
    3: 'a',
    4: 'b',
    5: 'c',
    6: 'c',
    7: 'd'
}

要求删除重复的 value 的 item,只保留一个,如何实现?

阅读 27.3k
5 个回答
tuple_r_dict = lambda _dict: dict(val[::-1] for val in _dict.iteritems()) # _dict.items() in Python3.x

tuple_r_dict(tuple_r_dict(z))

or

values=set()
for key in z.keys():
    val = z[key]
    if val in values: 
        del z[key]
    else:
        values.add(val)

我再加一个吧. 来晚了 T T

func = lambda z:dict([(x, y) for y, x in z.items()])
print func(func(z))

看LZ的意思,key不重要,这样的话:
set(z.values())

把dict中每项的key:value先翻转,自然形成一个去掉重复value的dict,再多翻转一次

a = {"abc":"11", "def":"11"}
b = {a[key]:key for key in a}
a = {b[key]:key for key in b}

UPDATE:才发现和@null的答案是一个思路,就算做个补充吧…

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题