如何按值对字典排序

Python字典是一种无序数据类型,因此,你无法通过其键或值对字典进行排序。但是你可以得到用其他数据类型表示的Python字典排序的结果,例如可以用列表来表示字典排序的结果。

假设我们有一个如下的字典,

exampleDict = {'first': 3, 'second': 4, 'third': 2, 'fourth': 1}

只获取已排序的值列表

sortedDict = sorted(exampleDict.values())
#Out: [1, 2, 3, 4]

使用operator.itemgetter对字典排序

import operator
sortedDict = sorted(exampleDict.items(), key=operator.itemgetter(1))
#Out: [('fourth', 1), ('third', 2), ('first', 3), ('second', 4)]

exampleDict.items返回字典元素的键值对。key=operator.itemgetter(1)指定比较键是字典的值,类似的,operator.itemgetter(0)会指定比较键为字典的键。

使用 lambda 函数作为 sorted函数中的比较键来对字典排序

你也可以使用lambda方程来作为比较键而不是用operator.itemgetter做键值。

sortedDict = sorted(exampleDict.items(), key=lambda x: x[1])
#Out: [('fourth', 1), ('third', 2), ('first', 3), ('second', 4)]

exampleDict.items()返回字典的键值对列表,其元素的数据类型为元组。x是这个元组的元素,其中x[0]是键,x[1]值是值。 key=lambda x:x[1]表示比较键是字典元素的值。

OrderedDict 数据类型来得到跟字典数据类型兼容的结果

上面示例代码的结果是列表,而不是字典类型。如果要将结果保持为字典兼容类型,那从Python 2.7开始引入的OrderedDict是一个不错的选择。

from collections import OrderedDict
sortedDict = OrderedDict(sorted(exampleDict.items(), key=lambda x: x[1]))
#Out: OrderedDict([('fourth', 1), ('third', 2), ('first', 3), ('second', 4)])

OrderedDict类型是Python字典 dict 的一个子类,它支持字典的常见方法,也能记住元素被插入的顺序。