sorted() 函数对所有可迭代的对象进行排序操作
sorted 语法:
sorted(iterable, key=None, reverse=False)
参数说明:
dir_info= {'a':1,'d':8,'c':3,'b':5}
#对字典按键(key)进行排序(默认由小到大)
dir_sort = sorted(dir_info.items(),key=lambda x:x[0])
print(dir_sort)
输出结果:
[('a', 1), ('b', 5), ('c', 3), ('d', 8)]
直接对字典的key排序
sorted({'a':1,'d':8,'c':3,'b':5}.keys())
dir_info= {'a':1,'d':8,'c':3,'b':5}
#对字典按键(key)进行排序(默认由小到大)
dir_sort = sorted(dir_info.items(),key=lambda x:x[1])
print(dir_sort)
输出结果
[('a', 1), ('c', 3), ('b', 5), ('d', 8)]
直接对字典的value排序
sorted({'a':1,'d':8,'c':3,'b':5}.values())
解析:
为了便于理解,再举个例子
person_info = [('zhangsan', '男', 15), ('lisi', '男', 12), ('wangwu', '男', 10),]
person_sort = sorted(person_info, key=lambda x: x[2])
print(person_sort)
输出结果:
[('wangwu', '男', 10), ('lisi', '男', 12), ('zhangsan', '男', 15)]
当然key的形式也是多样的
比如:
1.按照字符串长度进行排序
key = lambda x:len(x)
2.先按照第一个元素,再按照第二个元素:
key = lambda x : (x[0] , x[1])
根据ID降序排序 如果是升序负号去掉
[{'id': 5, 'filename': 'ums512_1h10.ini', 'time': '2021/2/2 19:08', 'branch': 'sprdroid10_trunk_19[0-9a-z]+', 'project': 'pac_config', 'remark': '', 'reviewers': 'xx,xx', 'watchers': 'xx'},
{'id': 14, 'filename': 'aaa', 'time': '2021/2/3 15:04', 'branch': 'develop', 'project': 'scm/ilib/mfservice', 'remark': '', 'reviewers': 'xx', 'watchers': 'xx'}]
reviewer_list.sort(key=lambda x: -x['id'])
将列表中数据的某一部分作为关键字进行排序(选取标志性可用于排序的元素作为条件)**
list_info = ['test-10.txt','test-11.txt','test-22.txt','test-14.txt','test-3.txt','test-20.txt']
list_sort = sorted(list_info, key=lambda d : int(d.split('-')[1].split('.')[0]))
print(list_sort)
输出结果
['test-3.txt', 'test-10.txt', 'test-11.txt', 'test-14.txt', 'test-20.txt', 'test-22.txt']