python中sorted方法和列表的sort方法使用详解(转)
一、语法:
list.sort([key][,reverse]) # 数字、字符串按照ASCII,中文按照unicode从小到大排序。排序会改变原有列表,不会形成副本,无返回值
new_list = sorted(list,[key][,reverse]) # 默认如果是数字则按由小到大排序,若是字符则按大写小于小写来排序。key在使用时必须提供一个排序过程总调用的函数,例长度key=len、绝对值key=abs。reverse实现降序或升序,reverse=Flase升序,reverse=True降序。返回一个有序的副本,并且类型总是列表。
二、基本形式
列表有自己的sort方法,其对列表进行原址排序,既然是原址排序,那显然元组不可能拥有这种方法,因为元组是不可修改的。
排序,数字、字符串按照ASCII,中文按照unicode从小到大排序
1 x = [4, 6, 2, 1, 7, 9] 2 x.sort() 3 print (x) 4 5 输出结果: 6 [1, 2, 4, 6, 7, 9]
如果需要一个排序好的副本,同时保持原有列表不变,需要这样实现:
1 x = [4, 6, 2, 1, 7, 9] 2 y = x[:] 3 y.sort() 4 print(y) # 输出结果 [1, 2, 4, 6, 7, 9] 5 print(x) # 输出结果 [4, 6, 2, 1, 7, 9]
注意:y = x[:] 通过分片操作将列表x的元素全部拷贝给y,如果简单的把x赋值给y: y = x ,y和x还是指向同一个列表,并没有产生新的副本。
另一种获取已排序的列表副本的方法是使用sorted函数:
1 x =[4, 6, 2, 1, 7, 9] 2 y = sorted(x) 3 print (y) # 输出结果 [1, 2, 4, 6, 7, 9] 4 print (x) #输出结果 [4, 6, 2, 1, 7, 9]
sorted返回一个有序的副本,并且类型总是列表,例如:
1 print (sorted('Python')) 2 3 输出结果 4 # ['P', 'h', 'n', 'o', 't', 'y']
1 # 有一个list['This','is','a','Boy','!'],所有元素都是字符串,对它进行大小写无关的排序 2 list=['This','is','a','Boy','!'] 3 list1=[i.lower() for i in list] # i.lower()将遍历的字符串转换成小写 4 # 如果需要sort形成副本,执行下面三个步骤 5 # new_list =list1[:] 6 # new_list.sort() 7 # print(new_list) 8 9 # 如果对原列表排序,不需要副本,执行下面两个步骤 10 list1.sort() # 对原列表进行排序,无返回值 11 print(list1) 12 13 # 如果需要副本用sorted,执行下面步骤 14 # new_list = sorted(list1) 15 # print(new_list) # 有返回值原列表没有变化
三、可选参数
sort方法还有两个可选参数:key和reverse
1、key在使用时必须提供一个排序过程总调用的函数:
1 x = ['mmm', 'mm', 'mm', 'm' ] 2 x.sort(key = len) 3 print (x) 4 5 # 输出结果: 6 # ['m', 'mm', 'mm', 'mmm']
2、reverse实现降序排序,需要提供一个布尔值(True为倒序排列,False为正序排列):
1 y = [3, 2, 8 ,0 , 1] 2 y.sort(reverse = True) 3 print (y) 4 5 # 输出结果 6 #[8, 3, 2, 1, 0]
四、例子
列表按照其中每一个值的绝对值排序
1 list1 = [1,3,5,-2,-4,-6] 2 list2 = sorted(l1,key=abs) 3 print(list1) 4 print(list2)
列表按照每一个元素的len排序
1 list1 = [[1,2],[3,4,5,6],(7,),'123'] 2 list2 = sorted(list1,key=len) 3 print(list2)
sort和sorted:
1 # 有一个list['This','is','a','Boy','!'],所有元素都是字符串,对它进行大小写无关的排序 2 list=['This','is','a','Boy','!'] 3 list1=[i.lower() for i in list] # i.lower()将遍历的字符串转换成小写 4 # 如果需要sort形成副本,执行下面三个步骤 5 # new_list =list1[:] 6 # new_list.sort() 7 # print(new_list) 8 9 # 如果对原列表排序,不需要副本,执行下面两个步骤 10 list1.sort() # 对原列表进行排序,无返回值 11 print(list1) 12 13 # 如果需要副本用sorted,执行下面步骤 14 # new_list = sorted(list1) 15 # print(new_list) # 有返回值原列表没有变化
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 19 >>> b = ['aa','BB','bb','zz','CC'] 20 >>> sorted(b) 21 ['BB', 'CC', 'aa', 'bb', 'zz'] #按列表中元素每个字母的ascii码从小到大排序,如果要从大到小,请用sorted(b,reverse=True)下同 22 23 >>> c =['CCC', 'bb', 'ffff', 'z'] 24 >>> sorted(c,key=len) #按列表的元素的长度排序 25 ['z', 'bb', 'CCC', 'ffff'] 26 27 >>> d =['CCC', 'bb', 'ffff', 'z'] 28 >>> sorted(d,key = str.lower ) #将列表中的每个元素变为小写,再按每个元素中的每个字母的ascii码从小到大排序 29 ['bb', 'CCC', 'ffff', 'z'] 30 31 >>> def lastchar(s): 32 return s[-1] 33 >>> e = ['abc','b','AAz','ef'] 34 >>> sorted(e,key = lastchar) #自定义函数排序,lastchar为函数名,这个函数返回列表e中每个元素的最后一个字母 35 ['b', 'abc', 'ef', 'AAz'] #sorted(e,key=lastchar)作用就是 按列表e中每个元素的最后一个字母的ascii码从小到大排序 36 37 >>> f = [{'name':'abc','age':20},{'name':'def','age':30},{'name':'ghi','age':25}] #列表中的元素为字典 38 >>> def age(s): 39 return s['age'] 40 >>> ff = sorted(f,key = age) #自定义函数按列表f中字典的age从小到大排序 41 42 [{'age': 20, 'name': 'abc'}, {'age': 25, 'name': 'ghi'}, {'age': 30, 'name': 'def'}] 43 44 >>> f2 = sorted(f,key = lambda x:x['age']) #如果觉得上面定义一个函数代码不美观,可以用lambda的形式来定义函数,效果同上