1. 程式人生 > >Python sorted() 高階函數

Python sorted() 高階函數

div ble list 一次 color iter 函數 指定 class

描述

sorted() 函數對所有可叠代的對象進行排序操作。

sort 與 sorted 區別:

sort 是應用在 list 上的方法,sorted 可以對所有可叠代的對象進行排序操作。

list 的 sort 方法返回的是對已經存在的列表進行操作,無返回值,而內建函數 sorted 方法返回的是一個新的 list,而不是在原來的基礎上進行的操作。

語法

sorted 語法:

sorted(iterable[, cmp[, key[, reverse]]])

參數說明:

  • iterable -- 可叠代對象。
  • cmp -- 比較的函數,這個具有兩個參數,參數的值都是從可叠代對象中取出,此函數必須遵守的規則為,大於則返回1,小於則返回-1,等於則返回0。
  • key -- 主要是用來進行比較的元素,只有一個參數,具體的函數的參數就是取自於可叠代對象中,指定可叠代對象中的一個元素來進行排序。
  • reverse -- 排序規則,reverse = True 降序 , reverse = False 升序(默認)。

返回值

返回重新排序的列表。

實例

以下實例展示了 sorted 的使用方法:

 1 >>>a = [5,7,6,3,4,1,2]
 2 >>> b = sorted(a)       # 保留原列表
 3 >>> a 
 4 [5, 7, 6, 3, 4, 1, 2]
 5 >>> b
6 [1, 2, 3, 4, 5, 6, 7] 7 8 >>> L=[(b,2),(a,1),(c,3),(d,4)] 9 >>> sorted(L, cmp=lambda x,y:cmp(x[1],y[1])) # 利用cmp函數 10 [(a, 1), (b, 2), (c, 3), (d, 4)] 11 >>> sorted(L, key=lambda x:x[1]) # 利用key 12 [(a, 1), (b, 2), (c, 3), (d, 4)]
13 14 15 >>> students = [(john, A, 15), (jane, B, 12), (dave, B, 10)] 16 >>> sorted(students, key=lambda s: s[2]) # 按年齡排序 17 [(dave, B, 10), (jane, B, 12), (john, A, 15)] 18 19 >>> sorted(students, key=lambda s: s[2], reverse=True) # 按降序 20 [(john, A, 15), (jane, B, 12), (dave, B, 10)] 21 >>>

註:key reverse 比一個等價的 cmp 函數處理速度要快。這是因為對於每個列表元素,cmp 都會被調用多次,而 keyreverse 只被調用一次

Python sorted() 高階函數