您好,登錄后才能下訂單哦!
本文小編為大家詳細介紹“Python排序sort()函數和sorted()函數怎么使用”,內容詳細,步驟清晰,細節處理妥當,希望這篇“Python排序sort()函數和sorted()函數怎么使用”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。
語法:
list.sort(cmp=None,key=None,reverse=False)
參數說明:
cmp:是用于比較函數(一般是阿斯克碼大小進行比較),比較對象是由key來決定的,一般不寫,系統默認。
key:是用來比較的元素對象,這里是傳入一個只有一個參數的函數,具體元素在可迭代對象中,這里可以指定可迭代對象中的一個元素為標準
reverse:意思是倒置,這個是一個布爾變量,意思是是否為降序,如果不填就默認為False(升序排序),如果填入了True就為降序排序
返回值
這個函數沒有返回值,是直接對列表進行排序處理
import random as r if __name__=='__main__': li=[i for i in range(1,11)] r.shuffle(li) print('排序前:',li) li.sort() print('排序后:',li) #輸出結果:排序前: [5, 9, 4, 3, 10, 2, 8, 6, 1, 7] # 排序后: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
import random as r if __name__=='__main__': li=['b','c','w','q','a','g','h'] r.shuffle(li) print('排序前:',li) li.sort() print('排序后:',li) #輸出結果:排序前: ['h', 'a', 'g', 'w', 'b', 'q', 'c'] # 排序后: ['a', 'b', 'c', 'g', 'h', 'q', 'w']
import random as r if __name__=='__main__': li=[i for i in range(1,19,2)] r.shuffle(li) print('排序前:',li) li.sort(reverse=True) print('排序后:',li) #輸出結果:排序前: [9, 1, 3, 15, 13, 17, 11, 5, 7] # 排序后: [17, 15, 13, 11, 9, 7, 5, 3, 1]
(1)寫法1
import random as r def lam(temp): return temp[1] if __name__=='__main__': li=[('李信',5),('李華',1),('李白',2),('韓信',4),('瑤',6)] r.shuffle(li) print('排序前:',li) li.sort(key=lam) print('排序后:',li) #輸出結果:排序前: [('瑤', 6), ('李華', 1), ('李信', 5), ('李白', 2), ('韓信', 4)] # 排序后: [('李華', 1), ('李白', 2), ('韓信', 4), ('李信', 5), ('瑤', 6)]
(2)寫法2
import random as rif __name__=='__main__': li=[('李信',5),('李華',1),('李白',2),('韓信',4),('瑤',6)] r.shuffle(li) print('排序前:',li) li.sort(key=lambda x:x[1]) print('排序后:',li)
通過設置key參數,我們可以自定義排序對象,這時候可以去實現列表里面的序列(元組等)進行排序
示例4:key的其他應用
import random as r if __name__=='__main__': li=[('李信',5),('李華',1),('李白',2),('韓信',4),('瑤',6)] r.shuffle(li) print('排序前:',li) li.sort(key=lambda x:x[1]) print('排序后:',li)
這種排序是按照二次函數y=x^2-8x+6 的單調性去排序的,key的用法很靈活。
語法:
sorted(literable,cmp=None,key=None,reverse=False)
參數:
literable:這個是表示可迭代對象,包括列表,元組,有序序列等等……
說明:這個函數的功能比sort()函數的功能更加強大,這個函數是可以對可迭代對象進行排序,而sort() 函數只能作用于列表中
返回值:這個函數的返回值是一個排序好了的列表,原來的可迭代對象內容是不會被修改的,而sort()函數是直接把原來的列表排序修改
示例:
import random as r if __name__=='__main__': li=[i for i in range(1,11)] r.shuffle(li) print('排序前:',li) new_li=sorted(li) print('原列表:',li) print('排序后new:',new_li) #輸出結果:排序前: [6, 3, 4, 8, 10, 1, 5, 9, 2, 7] # 原列表: [6, 3, 4, 8, 10, 1, 5, 9, 2, 7] # 排序后new: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
可以看出原來的列表是沒有被修改的。
讀到這里,這篇“Python排序sort()函數和sorted()函數怎么使用”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。