如何在 Python 中按键顺序对字典排序?
Python 的标准发行版包含集合模块。它包含高性能容器数据类型的定义。有序字典是字典的子类,它会记住添加到字典对象中的条目的顺序。当遍历有序字典时,将按照其键首先添加的顺序返回条目。
>>> from collections import OrderedDict >>> D = {5:'fff', 3:'ttt', 1:'ooo',4:'bbb', 2:'ddd'} >>> OrderedDict(D.items()) OrderedDict([(5, 'fff'), (3, 'ttt'), (1, 'ooo'), (4, 'bbb'), (2, 'ddd')])
我们还需要使用 sorted() 函数,该函数按指定顺序对可迭代对象中的元素进行排序。该函数将函数作为参数,用作排序的键。由于我们打算按键对字典进行排序,因此我们采用元组的第 0 个元素作为排序的键
>>> D = {5:'fff', 3:'ttt', 1:'ooo',4:'bbb', 2:'ddd'} >>> OrderedDict(sorted(D.items(), key = lambda t: t[0])) OrderedDict([(1, 'ooo'), (2, 'ddd'), (3, 'ttt'), (4, 'bbb'), (5, 'fff')])
可以将 OrderedDict 对象解析为常规字典对象
>>> D1 = dict(OrderedDict(sorted(D.items(), key = lambda t: t[0]))) >>> D1 {1: 'ooo', 2: 'ddd', 3: 'ttt', 4: 'bbb', 5: 'fff'}
广告