1、OrderedDict 的 popitem 方法
这种类型在添加键时会保持顺序,所以键的迭代顺序总是一致的。OrderedDict 的 popitem 默认删除和返回的方法是字典中的最后一个元素,但如果像 my_odict.popitem(last=False) 通过这种方式调用它,然后它删除并返回第一个被添加的元素。
move_to_end(key, last=True) 将现有 key 移到有序字典的末尾。如果 last=True(默认),然后 item 如果是,移动到右边 last=False,移动到开始。如果 key 如果不存在,就会引起 KeyError:
In[1]:fromcollectionsimportOrderedDict In[2]:d=OrderedDict.fromkeys('abcde') In[3]:d.move_to_end('b') In[4]:''.join(d.keys()) Out[4]:'acdeb' In[5]:d.move_to_end('b',last=False) In[6]:''.join(d.keys()) Out[6]:'bacde'
2、与 sorted 结合
由于 OrderedDict 会记住它的插入顺序,所以它可以与之相匹配 sorted 结合使用创建排序字典:
In[11]:d={'banana':3,'apple':4,'pear':1,'orange':2} #按key排序 In[12]:OrderedDict(sorted(d.items(),key=lambdat:t[0])) Out[12]:OrderedDict([('apple',4),('banana',3),('orange',2),('pear',1)]) #按value排序 In[13]:OrderedDict(sorted(d.items(),key=lambdat:t[1])) Out[13]:OrderedDict([('pear',1),('orange',2),('banana',3),('apple',4)]) #根据key的长度排序 In[14]:OrderedDict(sorted(d.items(),key=lambdat:len(t[0]))) Out[14]:OrderedDict([('pear',1),('apple',4),('banana',3),('orange',2)])
以上是python字典Ordeddict的实现,希望对大家有所帮助,python学习网有更多的知识。