sort方法
类似于reverse,sort方法也是List(列表)内建的函数,主要用于列表元素的排序,其语法为:
#key可以指定列表元素比较时用到的函数
#reverse默认时False(升序),指定为True时降序排列
List.sort(key=None,reverse=False)
注意:
- list方法支持数字、字符串排序,数字按大小排列,字符串按Ascii码排列,但是不支持数字和字符串混排
>>> list1 = [1,67,32,4,8]
>>> list1.sort()
>>> list1
[1, 4, 8, 32, 67]
>>> list2 = list('hellowrold')
>>> list2.sort()
>>> list2
['d', 'e', 'h', 'l', 'l', 'l', 'o', 'o', 'r', 'w']
>>> list3 = [1,'56','8',68,45]
>>> list3.sort()
TypeError: '<' not supported between instances of 'str' and 'int'
- list方法没有返回值,而是在原列表上进行排序
sorted函数
sorted函数是Python3内置的函数,主要用于可迭代对象的排序,参数为可迭代对象,包括字符串、元组、列表等,其语法为:
#seq为可迭代对象,也可以指定排序的函数key和是否降序排列
sorted(seq,key=None,reverse=False)
sort方法和sorted函数的异同
相同点
- 两种操作的作用都会排序,都可以对列表进行升序(或降序)或者其他指定排序
- 参数key和reverse的值通用
不同点
- sort方法仅仅可以在列表中使用,而sorted函数的参数是可迭代对象,可以是字符串,元组,列表等,通用性更强
- sort方法没有返回值,在原列表上修改;而sorted函数不会修改原数组,返回的是排序后的列表
应用
1.常规排序
默认升序排列,如果想降序排列则参数要指定reverse=True
- 对于数字,按数值大小排序;
- 对于单个字符,按Ascii码对应数字大小排序;如果是字符串,则先比较索引为0位置的Ascii码;如果索引为0处字符相等,再依次比较索引为1、2......处的Ascii大小
- 对于布尔值,False<True
list1 = [32,6,-7,12,9,0]
#升序排列
list1.sort() #list1此时为[-7, 0, 6, 9, 12, 32]
#降序排列
list1.sort(reverse=True)#list1此时为[32, 12, 9, 6, 0, -7]
list2 = list('helloworld')
sorted(list2) #['d', 'e', 'h', 'l', 'l', 'l', 'o', 'o', 'r', 'w']
list3 = 'I am a student now'.split()
list3.sort() #['I', 'a', 'am', 'now', 'student']
list4 = [False,True]
list4.sort() # list4为[False,True]
list4.sort(reverse=True) #list4为[True,False]
2.内嵌列表排序
内嵌列表的排序类似于字符串,例如列表[[a,b,c], [x,y,z]]
排序,则先比较a和x,如果a==x
,则再计较b和y,依次类推。
>>> list1 = [3,-2,4,7,23,-5]
>>> sorted(list(map(lambda x :[x%3 ,abs(x)], list1)))
[[0, 3], [1, 2], [1, 4], [1, 5], [1, 7], [2, 23]]
3.指定排序的参数k
很多时候我们想要自定义排序方式,可以将函数指定给参数k来实现,例如我们对单个字符进行排序时希望忽略大小写带来的影响,即字母w(或W)永远排在字母a(或A)后
>>> str1 = 'hellOworLD'
>>> sorted(str1) #默认排序
['D', 'L', 'O', 'e', 'h', 'l', 'l', 'o', 'r', 'w']
#指定参数k
>>> sorted(str1,key=str.lower)
['D', 'e', 'h', 'l', 'l', 'L', 'O', 'o', 'r', 'w']
4.多条件排序
有时候我们希望可以按照更复杂的条件来排序,例如对于列表[-7,24,3,18,-9,22]
我们可以可以按照以下条件排序:
1.正数在前负数在后2.整数从小到大 3.负数从大到小
>>> list1 = [-7,24,3,18,-9,22]
>>> sorted(list1,key=lambda x: (x < 0, abs(x)))
[3, 18, 22, 24, -7, -9]