一、sort函数
sort函数是序列的内部函数
函数原型:
L.sort(cmp=None, key=None, reverse=False)
函数作用:
它是把L原地排序,也就是使用后并不是返回一个有序的序列副本,而是把当前序列变得有序
参数说明:
(1) cmp参数
cmp接受一个函数,拿整形举例,形式为:
def f(a,b):
return a-b
如果排序的元素是其他类型的,如果a逻辑小于b,函数返回负数; a逻辑等于b,函数返回0; a逻辑大于b,函数返回正数就行了
(2) key参数
key也是接受一个函数,不同的是,这个函数只接受一个元素,形式如下
def f(a):
return len(a)
key接受的函数返回值,表示此元素的权值,sort将按照权值大小进行排序
(3) reverse参数
接受False 或者True 表示是否逆序
sort举例:
(1)按照元素长度排序
L = [{1:5,3:4},{1:3,6:3},{1:1,2:4,5:6},{1:9}]
def f(x):
return len(x)
sort(key=f)
print L
输出:
[{1: 9}, {1: 5, 3: 4}, {1: 3, 6: 3}, {1: 1, 2: 4, 5: 6}]
(2)按照每个字典元素里面key为1的元素的值排序
L = [{1:5,3:4},{1:3,6:3},{1:1,2:4,5:6},{1:9}]
def f2(a,b):
return a[ 1 ]-b[ 1 ]
L.sort(cmp=f2)
print L
输出:
[{1: 1, 2: 4, 5: 6}, {1: 3, 6: 3}, {1: 5, 3: 4}, {1: 9}]
二、sorted函数
sorted函数是内建函数,他接受一个序列,返回有序的副本
他与sort的唯一区别就是会返回副本
python的排序函数sort,sorted在列表排序和字典排序中的应用详解和举例
python 列表list中内置了一个十分有用的排序函数sort,sorted,它可以用于列表的排序,以下是例子。
1. a = [5,2,1,9,6]
2.
3. >>> sorted(a) #将a从小到大排序,不影响a本身结构
4. [1, 2, 5, 6, 9]
5.
6. >>> sorted(a,reverse = True) #将a从大到小排序,不影响a本身结构
7. [9, 6, 5, 2, 1]
8.
9. >>> a.sort() #将a从小到大排序,影响a本身结构
10. >>> a
11. [1, 2, 5, 6, 9]
12.
13. >>> a.sort(reverse = True) #将a从大到小排序,影响a本身结构
14. >>> a
15. [9, 6, 5, 2, 1]
16.
17. 注意,a.sort() 已改变其结构,b = a.sort() 是错误的写法!
18. >>> b = ['aa','BB','bb','zz','CC']
19. >>> sorted(b)
20. ['BB', 'CC', 'aa', 'bb', 'zz'] #按列表中元素每个字母的ascii码从小到大排序,如果要从大到小,请用sorted(b,reverse=True)下同
21.
22. >>> c =['CCC', 'bb', 'ffff', 'z']
23. >>> sorted(c,key=len) #按列表的元素的长度排序
24. ['z', 'bb', 'CCC', 'ffff']
25.
26. >>> d =['CCC', 'bb', 'ffff', 'z']
27. >>> sorted(d,key = str.lower ) #将列表中的每个元素变为小写,再按每个元素中的每个字母的ascii码从小到大排序
28. ['bb', 'CCC', 'ffff', 'z']
29.
30. >>> def lastchar(s):
31. return s[-1]
32. >>> e = ['abc','b','AAz','ef']
33. >>> sorted(e,key = lastchar) #自定义函数排序,lastchar为函数名,这个函数返回列表e中每个元素的最后一个字母
34. ['b', 'abc', 'ef', 'AAz'] #sorted(e,key=lastchar)作用就是 按列表e中每个元素的最后一个字母的ascii码从小到大排序
35.
36. >>> f = [{'name':'abc','age':20},{'name':'def','age':30},{'name':'ghi','age':25}] #列表中的元素为字典
37. >>> def age(s):
38. return s['age']
39. >>> ff = sorted(f,key = age) #自定义函数按列表f中字典的age从小到大排序
40.
41. [{'age': 20, 'name': 'abc'}, {'age': 25, 'name': 'ghi'}, {'age': 30, 'name': 'def'}]
42.
43. >>> f2 = sorted(f,key = lambda x:x['age']) #如果觉得上面定义一个函数代码不美观,可以用lambda的形式来定义函数,效果同上