问题
怎样实现一个键对应多个值的字典(也叫multidcit)?
解决方案
一个字典就是一个键对应一个单值的映射。如果你想要一个键映射多个值,那么你就㤇将这么多个值放到另外的容器中,比如列表或者集合里面。比如,你可以像下面这样构造这样的字典:
选择使用列表还是集合取决于你的实际需求。如果你想保持元素的插入顺序就应该使用列表,如果想去掉重复元素就使用集合(并且不关心元素的顺序问题)。
你可以很方便的使用collection模块中的defaultdict来构造这样的字典。defaultdict的一个特征是它会自动初始化每个key刚开始对应的值,所以你只需要关注添加元素操作了。比如:
from collections import defaultdict
d=defaultdict(list)
d['a'].append(1)
d['a'].append(2)
d['b'].append(4)
print(d)
# -》defaultdict(<class 'list'>, {'a': [1, 2], 'b': [4]})
d=defaultdict(set)
d['a'].add(1)
d['b'].add(2)
d['b'].add(4)
print(d)
需要注意的是,defaultdict会自动为将要访问的键(就算目前字典中并不存在这样的键)创建映射实体。如果你并不需要这样的特性,你可以在一个普通的字典上使用setdefault()方法来代替。比如:
d={}
d.setdefault('a',[]).append(1)
d.setdefault('a',[]).append(2)
d.setdefault('b',[]).append(4)
print(d) # {'a': [1, 2], 'b': [4]}
但是很多程序员觉得setdefault()用起来有点别扭。因为每次调用都得创建又给新的初始值的实例(例子程序中的空列表[])
构建多值字典:实现与容器的选择
本文介绍如何在Python中实现键对应多个值的字典,通过列表和集合来存储值,并演示了defaultdict的使用。同时讨论了setdefault与defaultdict的区别,以及根据需求选择合适的容器。
2127

被折叠的 条评论
为什么被折叠?



