Python 排序 – sort()、sorted()
1. 列表排序:sort()
函数原型: 直接对列表本身进行排序,不会返回新的列表
list.sort(cmp=None, key=None, reverse=False)
参数:
- cmp:指定排序的方法
- key:指定排序的元素,通常用 lambda 函数
- reverse:排序规则,默认为 False 升序,True为降序
实例:
# 一维类表排序
a = [2, 5, 1, 4, 3]
a.sort()
=> a: [1, 2, 3, 4, 5]
# 二维类表排序,x表示可迭代对象的元素
b = [[1,1], [1,5] ,[2,3]]
b.sort(key=lambda x : x[1])
=> b: [[1, 1], [2, 3], [1, 5]]
b.sort(key=lambda x : x[0])
=> b: [[1, 1], [1, 5], [2, 3]]
2. 通用排序:sorted()
函数原型: 迭代对象本身不变,返回新的迭代对象
sorted(iterable, key=None, reverse=False)
参数:
- iterable:可迭代对象
- key:指定排序的元素,通常用 lambda 函数
- reverse:排序规则,默认为 False 升序,True为降序
实例:
# 类表排序
a = [2, 5, 1, 4, 3]
res = sorted(a)
=>res: [1, 2, 3, 4, 5]
=>a: [2, 5, 1, 4, 3]
3. 字典排序
# 默认按 key 进行排序,返回 keys 的列表
a = {1: 'D', 2: 'B', 3: 'B', 4: 'E', 5: 'A'}
sorted(a)
=> [1, 2, 3, 4, 5]
# 按 key 进行排序,返回字典列表
sorted(a.items())
=> [(1, 'D'), (2, 'B'), (3, 'B'), (4, 'E'), (5, 'A')]
# 按 value 进行排序,返回 values 的列表
sorted(a.values())
=> ['A', 'B', 'B', 'D', 'E']
# 按 value 进行排序,返回字典列表
sorted(a.items(), key=lambda x:x[1])
=> [(5, 'A'), (2, 'B'), (3, 'B'), (1, 'D'), (4, 'E')]