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)])
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。