列表有自己的sort方法,其对列表进行原址排序,既然是原址排序,那显然元组不可能拥有这种方法,因为元组是不可修改的。
排序,数字、字符串按照ASCII,中文按照unicode从小到大排序
1
2
3
|
x = [ 4 , 6 , 2 , 1 , 7 , 9 ] x.sort() print (x) # [1, 2, 4, 6, 7, 9] |
如果需要一个排序好的副本,同时保持原有列表不变,怎么实现呢?
1
2
3
4
5
|
x = [ 4 , 6 , 2 , 1 , 7 , 9 ] y = x[:] y.sort() print (y) # [1, 2, 4, 6, 7, 9] print (x) # [4, 6, 2, 1, 7, 9] |
注意:y = x[:] 通过分片操作将列表x的元素全部拷贝给y,如果简单的把x赋值给y:y = x,y和x还是指向同一个列表,并没有产生新的副本。
另一种获取已排序的列表副本的方法是使用sorted函数:
1
2
3
4
|
x = [ 4 , 6 , 2 , 1 , 7 , 9 ] y = sorted (x) print (y) #[1, 2, 4, 6, 7, 9] print (x) #[4, 6, 2, 1, 7, 9] |
sorted返回一个有序的副本,并且类型总是列表,如下:
1
|
print ( sorted ( 'Python' )) #['P', 'h', 'n', 'o', 't', 'y'] |
1
2
3
4
5
6
7
8
|
# 2.有一个list['This','is','a','Boy','!'],所有元素都是字符串,对它进行大小写无关的排序 li = [ 'This' , 'is' , 'a' , 'Boy' , '!' ] l = [i.lower() for i in li] # l1 =l[:] l.sort() # 对原列表进行排序,无返回值 print (l) # print(sorted(l1)) # 有返回值原列表没有变化 # print(l1) |
sort方法还有两个可选参数:key和reverse
1、key在使用时必须提供一个排序过程总调用的函数:
1
2
3
|
x = [ 'mmm' , 'mm' , 'mm' , 'm' ] x.sort(key = len ) print (x) # ['m', 'mm', 'mm', 'mmm'] |
2、reverse实现降序排序,需要提供一个布尔值:
1
2
3
|
y = [ 3 , 2 , 8 , 0 , 1 ] y.sort(reverse = True ) print (y) #[8, 3, 2, 1, 0] |
True为倒序排列,False为正序排列