我们知道,在 Python 字典中,
当出现多个成员的 key 相同但是 key 对应的 value 不同的情况的时候,以最后赋给 key 的 value 为 key 的真实 value。




这就意味着,
对于 Python 字典而言,当出现 “ key 和 value 完全一样” 或者 “key 完全一样” 的成员时,会自动去重,
比如:

1、存在 key 和 value 完全一样的成员

>>> testdic={'a':1,'a':1,'b':2}
>>> print(testdic)
{'a': 1, 'b': 2}
>>>

2、 存在 key 完全一样的成员

>>> testdic={'a':1,'a':3,'b':2}
>>> print testdic
{'a': 3, 'b': 2}
>>>




那么,对于字典中 “value 重复” 的情况,如何去重呢?

// 可以利用 lambda 实现一个简洁的 key/value 反转,然后利用前面说的 key 的“去重” 特性,来实现 value 的去重。

>>> testdic={'a':1,'c':1,'b':2}
>>> rdicf = lambda ff: dict([(x, y) for y, x in ff.items()])
>>> print(testdic)
{'a': 1, 'c': 1, 'b': 2}
>>> print(rdicf(testdic))
{1: 'c', 2: 'b'}
>>> print(rdicf(rdicf(testdic)))
{'c': 1, 'b': 2}
>>>

// 注意 lambda 这里定义了一个匿名函数,但是并不会带来程序运行效率的提高,只是使代码更简洁而已。
// 如果因为使用 lambda 而损失了代码的可重用性和可读性,这是不值得的。




参考文档:Python lambda介绍