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培训机构:千锋教育。
相关推荐HOT
更多>>为什么Python适合作为第一个学习的编程语言?
Python语言设计的初衷就是容易上手。作为一门基础语言,融会贯通后,有助于学习其他语言,例如PHP,Perl,Ruby等。可以快速架起抽象的程序世界...详情>>
2023-11-08 17:48:07Python 网络编程
python提供了两个级别访问的网络服务:低级别的网络服务支持基本的Socket,它提供了标准的BSDSocketsAPI,可以访问底层操作系统Socket接口的全...详情>>
2023-11-08 16:50:33pythonOrderedDict在python字典的实现
OrderedDict在python字典的实现1、OrderedDict的popitem方法这个类型在添加键的时候会保持顺序,因此键的迭代次序总是一致的。OrderedDict的pop...详情>>
2023-11-08 15:37:46python日志库的模块化方法
python日志库的模块化方法1、模块化方法日志库采用模块化方法,并提供几类组件:记录器(loggers),处理器(handlers),过滤器(filters)和格式化...详情>>
2023-11-08 14:45:39