问题描述
我们有一个字典列表,想根据一个或多个字典中的值来对列表排序。
例如,有如下字典列表,根据字典中的x,由大到小排序这个列表:
解决方案
排序用sorted内置函数,关键字key参数用lambda表达式取出字典中x值作为排序依据,关键字reverse参数设置为True用来由大到小降序排序。
也可以用operator模块中的itemgetter函数取出字典中某个键的值,作为排序依据。
讨论
函数operator.itemgetter()接受的参数可以作为查询的标记,它可以是字典的键名称、用数字表示的列表元素或是任何可以传给对象的__getitem__()
方法的值。如果传多个标记给itemgetter(),那么它产生的可调用对象将返回一个包含所有元素在内的元组,然后sorted()将根据对元组的排序结果来排列输出结果。如果想同时针对多个字段做排序(比如x和y),那么这是非常有用的。
有时候会用lambda表达式来取代itemgetter()的功能。例如:
这种解决方案通常也能正常工作,但是用itemgetter()通常会运行得更快一些。因此如果要考虑性能问题的话,应该使用itemgetter()。
最后不要忘了本文中展示的技术同样适用于min()和max()函数。例如: