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]: from collections import OrderedDict

 

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=lambda t:t[0]))

Out[12]: OrderedDict([('apple', 4), ('banana', 3), ('orange', 2), ('pear', 1)])

# 根据 value 排序

In [13]: OrderedDict(sorted(d.items(), key=lambda t:t[1]))

Out[13]: OrderedDict([('pear', 1), ('orange', 2), ('banana', 3), ('apple', 4)])

# 根据 key 的长度排序

In [14]: OrderedDict(sorted(d.items(), key=lambda t: len(t[0])))

Out[14]: OrderedDict([('pear', 1), ('apple', 4), ('banana', 3), ('orange', 2)])

以上就是OrderedDict在python字典" title="python字典">python字典的实现,希望能对大家有所帮助,更多知识尽在python学习网。

以上是 OrderedDict在python字典的实现 的全部内容, 来源链接: utcz.com/z/543484.html

回到顶部