pythonOrderedDict在python字典的实现
OrderedDict在python字典的实现
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)])
以上就是OrderedDict在python字典的实现,希望能对大家有所帮助,更多Python学习教程请关注IT培训机构:筋斗云。