字典是一种关联容器,每个键都映射到一个单独的值上,如果想让键映射到多个值,需要将这多个值保存到另一个容器如列表或集合中

如果希望保留元素插入的顺序,就用列表;如果希望消除重复元素且不在意他们的顺序,就用集合

1.collections模块中的defaultdict类

  1)  defaultdict类的一个特点是它会自动初始化第一个值,这样只需要关注添加元素即可

  

d = defaultdict(set)
 
    d['a'].add(1)

    或

   

d = defaultdict(list)
    d['a'].append(1)

  2)  defaultdict会自动创建字典表项以待稍后的访问(即使这些表项在字典中还没有找到,若不想使用此功能,可以在普通的字典上调用setdefault()方法来取代

    如

d = {}#  a regular dictionary
    d.setdefault('a',[]).append()

2. collections中的OrderedDict类

  3) 让字典保持有序,对字典做迭代时,会按照元素初始添加的顺序进行

    当想构建一个映射结构一遍稍后进行序列化或转换为另一种格式时,OrderedDict类非常有用,如进行JSON编码时希望精确控制各字段的顺序,那么首先在OrderedDict中构建数据即可

  2) OrderedDict内部维护了一个双向链表,会根据元素加入的顺序来排列键的位置,新加入的元素被放在链表末尾,对已存在的键重新赋值不会改变键的顺序

    OrderedDict的内存开支是普通字典的两倍多,是由于额外创建的链表所致,构建一个涉及大量OrderedDict实例的数据结构,需要权衡使用OrderedDict的好处能否超过内存开销带来的缺点