玩蛇网提供最新Python编程技术信息以及Python资源下载!
您现在的位置: 玩蛇网首页 > Python问题解答 > 正文内容

Python字典操作的问题,要删除字典内部重复值item操作方法

字典 z 如下

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

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

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的答案是一个思路,就算做个补充吧…

还是保留任意一个?比如{'a':1, 'b':1} 结果是空,还是剩下一个item?

玩蛇网文章,转载请注明出处和文章网址:http://www.iplaypy.com/wenda/wd20464.html

相关文章 Recommend

玩蛇网Python互助QQ群,欢迎加入-->: 106381465 玩蛇网Python新手群
修订日期:2017年06月01日 - 10时10分23秒 发布自玩蛇网

我要分享到:

必知PYTHON教程 Must Know PYTHON Tutorials

必知PYTHON模块 Must Know PYTHON Modules