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