一、語法:
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的形式來定義函數,效果同上