1. 程式人生 > >Python 排序 -- sort()、sorted()

Python 排序 -- sort()、sorted()

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')]