字典排序
Posted 王王的王
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了字典排序相关的知识,希望对你有一定的参考价值。
#按照数字从小到大排序
#字典是无序的,需要转成list,转换成二位数组,指定key元素位置返回
#字典或者多维数组排序
stu_score = {
"a": 100,
"b": 99,
"c": 77,
"d": 23523,
"e": 232,
"f": 2323
}
def func(l):
return l[0]
#方式一
print(dict(sorted(stu_score.items(),key=func)))
方式二 sorted帮你循环
print(dict(sorted(stu_score.items(),key=lambda l:l[-1]))) #转成二维数组有两个元素
#sorted(stu_score.items())#转成二维数组有两个元素,按照第一个元素排序的
python中列表排序,字典排序,列表中的字典排序
#-*- encoding=utf-8 -*- import operator #按字典值排序(默认为升序) x = {1:2, 3:4, 4:3, 2:1, 0:0} sorted_x = sorted(x.iteritems(), key=operator.itemgetter(1)) print sorted_x #[(0, 0), (2, 1), (1, 2), (4, 3), (3, 4)] #如果要降序排序,可以指定reverse=True sorted_x = sorted(x.iteritems(), key=operator.itemgetter(1), reverse=True) print sorted_x #[(3, 4), (4, 3), (1, 2), (2, 1), (0, 0)] #或者直接使用list的reverse方法将sorted_x顺序反转 #sorted_x.reverse() #取代方法是,用lambda表达式 sorted_x = sorted(x.iteritems(), key=lambda x : x[1]) print sorted_x #[(0, 0), (2, 1), (1, 2), (4, 3), (3, 4)] sorted_x = sorted(x.iteritems(), key=lambda x : x[1], reverse=True) print sorted_x #[(3, 4), (4, 3), (1, 2), (2, 1), (0, 0)] #包含字典dict的列表list的排序方法与dict的排序类似,如下: x = [{‘name‘:‘Homer‘, ‘age‘:39}, {‘name‘:‘Bart‘, ‘age‘:10}] sorted_x = sorted(x, key=operator.itemgetter(‘name‘)) print sorted_x #[{‘age‘: 10, ‘name‘: ‘Bart‘}, {‘age‘: 39, ‘name‘: ‘Homer‘}] sorted_x = sorted(x, key=operator.itemgetter(‘name‘), reverse=True) print sorted_x #[{‘age‘: 39, ‘name‘: ‘Homer‘}, {‘age‘: 10, ‘name‘: ‘Bart‘}] sorted_x = sorted(x, key=lambda x : x[‘name‘]) print sorted_x #[{‘age‘: 10, ‘name‘: ‘Bart‘}, {‘age‘: 39, ‘name‘: ‘Homer‘}] sorted_x = sorted(x, key=lambda x : x[‘name‘], reverse=True) print sorted_x #[{‘age‘: 39, ‘name‘: ‘Homer‘}, {‘age‘: 10, ‘name‘: ‘Bart‘}]
以上是关于字典排序的主要内容,如果未能解决你的问题,请参考以下文章
初识Spring源码 -- doResolveDependency | findAutowireCandidates | @Order@Priority调用排序 | @Autowired注入(代码片段
初识Spring源码 -- doResolveDependency | findAutowireCandidates | @Order@Priority调用排序 | @Autowired注入(代码片段