我希望在Python中构建一个字典,其中不同的键引用相同的元素。我有以下这个字典:
persons = {"George":'G.MacDonald', "Luke":'G.MacDonald', "Larry":'G.MacDonald'}
关键字都指向相同的字符串,但这些字符串在程序内部有不同的内存位置。我想创建一个字典,使所有这些关键字都指向同一个元素,这是否可能?
我希望在Python中构建一个字典,其中不同的键引用相同的元素。我有以下这个字典:
persons = {"George":'G.MacDonald', "Luke":'G.MacDonald', "Larry":'G.MacDonald'}
关键字都指向相同的字符串,但这些字符串在程序内部有不同的内存位置。我想创建一个字典,使所有这些关键字都指向同一个元素,这是否可能?
您可以像下面这样操作:
import itertools as it
unique_dict = {}
value_key=lambda x: x[1]
sorted_items = sorted(your_current_dict.items(), key=value_key)
for value, group in it.groupby(sorted_items, key=value_key):
for key in group:
unique_dict[key] = value
这将把你的字典转换为一个字典,其中任何类型(但可比较)相等的值都是唯一的。如果你的值不可比较(但是可哈希),你可以使用一个临时的dict
:
from collections import defaultdict
unique_dict = {}
tmp_dict = defaultdict(list)
for key, value in your_current_dict.items():
tmp_dict[value].append(key)
for value, keys in tmp_dict.items():
unique_dict.update(zip(keys, [value] * len(keys)))
如果你正在使用Python 3,sys.intern
提供了一个非常优雅的解决方案:
for k in persons:
persons[k] = sys.intern(persons[k])
interned = { v:v for v in set(persons.itervalues()) }
for k in persons:
persons[k] = interned[persons[k]]
interned = dict( (v, v) for … )
来编写代码。
foo = 'G.MacDonald'; persons = {'George': foo, 'Luke': foo, 'Larry': foo}
- JosefAssad