詳解Python中sorted()和sort()的使用與區(qū)別
在 Python 中,你可以使用 sorted() 方法或 sort() 方法對(duì)數(shù)據(jù)進(jìn)行排序。
在本文中,我將提供 sorted() 和 sort() 方法的代碼示例,并解釋兩者之間的區(qū)別。
sort()方法是什么
此方法接受一個(gè)列表并對(duì)其進(jìn)行排序。但,請(qǐng)記住此方法沒(méi)有返回值,即返回None。
下面例子中,我們有一個(gè)數(shù)字列表,我們可以使用 sort() 方法按升序?qū)α斜磉M(jìn)行排序。
my_list = [67, 2, 999, 1, 15] # 輸入未排序列表 print("Unordered list: ", my_list) # sort() 方法本地排序列表my_list,默認(rèn)從小到達(dá) my_list.sort() # this prints the ordered list print("Ordered list: ", my_list)
輸出:
Unordered list: [67, 2, 999, 1, 15]
Ordered list: [1, 2, 15, 67, 999]
注意: my_list.sort() 是對(duì)列表 my_list僅本地排序,返回返回為 None。
如下代碼:
my_list_1 = [6, 7, 8, 9, 10] print(my_list_1.sort()) # my_list_1 已排序,返回為None my_list_2 = [6, 7, 8, 9, 10] print(my_list_2.sort()) # my_list_2 未排序,返回依然為None,但my_list_2 已經(jīng)被改變了
輸出:
None
None
繼續(xù)思考!sort()默認(rèn)為升序排序,如果想降序排序了?
其實(shí)sort() 方法可以接受兩個(gè)可選參數(shù),稱(chēng)為 key 和 reverse。
key 具有將在列表中的每個(gè)項(xiàng)目上調(diào)用的函數(shù)的值。
在這個(gè)例子中,我們可以使用 len() 函數(shù)作為 key 參數(shù)的值。key=len 將告訴計(jì)算機(jī)按長(zhǎng)度從最小到最大對(duì)名稱(chēng)列表進(jìn)行排序。
names = ["Jessica", "Ben", "Carl", "Jackie", "Wendy"] print("Unsorted: ", names) names.sort(key=len) print("Sorted: ", names)
輸出:
Unsorted: ['Jessica', 'Ben', 'Carl', 'Jackie', 'Wendy']
Sorted: ['Ben', 'Carl', 'Wendy', 'Jackie', 'Jessica']
reverse 有兩個(gè)布爾值,True 或 False。
在這個(gè)例子中,reverse=True 將告訴計(jì)算機(jī)以逆字母順序?qū)α斜磉M(jìn)行排序。
names = ["Jessica", "Ben", "Carl", "Jackie", "Wendy"] print("Unsorted: ", names) names.sort(reverse=True) print("Sorted: ", names) Unsorted: ['Jessica', 'Ben', 'Carl', 'Jackie', 'Wendy'] Sorted: ['Wendy', 'Jessica', 'Jackie', 'Carl', 'Ben']
如何妙用sorted() 方法
此方法將從可迭代對(duì)象返回一個(gè)新的排序列表??傻鷮?duì)象包括列表、字符串和元組等等。
sort() 和 sorted() 之間的一個(gè)主要區(qū)別是 sorted() 將返回一個(gè)新列表,而 sort() 對(duì)列表進(jìn)行原地排序。
請(qǐng)記住: sorted() 將返回一個(gè)新列表,而 sort() 對(duì)列表進(jìn)行原地排序。
在這個(gè)例子中,我們有一個(gè)按升序排序的數(shù)字列表。
sorted_numbers = sorted([77, 22, 9, -6, 4000]) print("升序排序: ", sorted_numbers)
輸出:
升序排序: [-6, 9, 22, 77, 4000]
前方高能,繼續(xù)深挖sorted()!
sorted() 方法還接受可選的 key 和 reverse 參數(shù)。
在這個(gè)例子中,我們有一個(gè)按降序排序的數(shù)字列表。reverse=True 告訴計(jì)算機(jī)將列表從最大到最小反轉(zhuǎn)。
sorted_numbers = sorted([77, 22, 9, -6, 4000], reverse=True) print("降序排序: ", sorted_numbers)
輸出:
降序排序: [4000, 77, 22, 9, -6]
sorted() 和 sort() 之間的另一個(gè)主要區(qū)別是 sorted() 方法接受任何可迭代對(duì)象,而 sort() 方法僅適用于列表。
在此示例中,我們使用 split() 方法將字符串分解為單個(gè)單詞。然后我們使用 sorted() 按長(zhǎng)度從最小到最大對(duì)單詞進(jìn)行排序。
my_sentence = "i love python! you like what?" print("原字符串: ", my_sentence) print(sorted(my_sentence.split(), key=len))
輸出:
['i', 'you', 'love', 'like', 'what?', 'python!']
我們還可以修改此示例,并包含 key 和 reverse 參數(shù)。
這個(gè)修改后的示例現(xiàn)在將從最大到最小對(duì)列表進(jìn)行排序。
my_sentence = "i love python! you like what?" print("原字符串: ", my_sentence) print(sorted(my_sentence.split(), key=len, reverse=True))
輸出:
['python!', 'what?', 'love', 'like', 'you', 'i']
我們還可以對(duì)元組使用 sorted() 方法。
在這個(gè)例子中,我們有一個(gè)代表樂(lè)隊(duì)學(xué)生姓名、年齡和樂(lè)器的元組集合。
band_students = [ ('Danny', 17, 'Trombone'), ('Mary', 14, 'Flute'), ('Josh', 15, 'Percussion') ]
我們可以使用 sorted() 方法按學(xué)生的年齡對(duì)這些數(shù)據(jù)進(jìn)行排序。該鍵具有 lambda 函數(shù)的值,該函數(shù)告訴計(jì)算機(jī)按年齡升序排序。
lambda 函數(shù)是沒(méi)有名稱(chēng)的匿名函數(shù)。你可以使用 lambda 關(guān)鍵字來(lái)定義這種類(lèi)型的函數(shù)。
lambda student: student[1]
要訪(fǎng)問(wèn)元組中的值,請(qǐng)使用括號(hào)表示法和要訪(fǎng)問(wèn)的索引號(hào)。由于我們從零開(kāi)始計(jì)數(shù),因此年齡值為 [1]。
這是完整的示例。
band_students = [ ('Danny', 17, 'Trombone'), ('Mary', 14, 'Flute'), ('Josh', 15, 'Percussion') ] print(sorted(band_students, key=lambda student: student[1]))
輸出:
[('Mary', 14, 'Flute'), ('Josh', 15, 'Percussion'), ('Danny', 17, 'Trombone')]
我們可以修改此示例,并改為按樂(lè)器對(duì)數(shù)據(jù)進(jìn)行排序。我們可以使用 reverse 通過(guò)反向字母順序?qū)ぞ哌M(jìn)行排序。
band_students = [ ('Danny', 17, 'Trombone'), ('Mary', 14, 'Flute'), ('Josh', 15, 'Percussion') ] print(sorted(band_students, key=lambda student: student[2], reverse=True))
輸出:
[('Danny', 17, 'Trombone'), ('Josh', 15, 'Percussion'), ('Mary', 14, 'Flute')]
總結(jié)
在本文中,我們學(xué)習(xí)了如何使用 Python 的 sort() 和 sorted() 方法。
sort() 方法僅適用于列表,并對(duì)列表進(jìn)行排序。它沒(méi)有返回值。
sorted() 方法適用于任何可迭代對(duì)象,并返回一個(gè)新的排序列表。可迭代對(duì)象的示例包括列表、字符串和元組。
這兩種方法都有 key 和 reverse 兩個(gè)可選參數(shù)。
key 具有將在列表中的每個(gè)項(xiàng)目上調(diào)用的函數(shù)的值。
reverse 的布爾值為 True 或 False。
此方法接受一個(gè)列表并對(duì)其進(jìn)行排序。但,請(qǐng)記住此方法沒(méi)有返回值。
到此這篇關(guān)于詳解Python中sorted()和sort()的使用與區(qū)別的文章就介紹到這了,更多相關(guān)Python sorted() sort()內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python神經(jīng)網(wǎng)絡(luò)學(xué)習(xí)利用PyTorch進(jìn)行回歸運(yùn)算
這篇文章主要為大家介紹了python神經(jīng)網(wǎng)絡(luò)學(xué)習(xí)利用PyTorch進(jìn)行回歸運(yùn)算的實(shí)現(xiàn)代碼,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05如何使用Python實(shí)現(xiàn)斐波那契數(shù)列
這篇文章主要介紹了如何使用Python實(shí)現(xiàn)斐波那契數(shù)列,斐波那契數(shù)列(Fibonacci)最早由印度數(shù)學(xué)家Gopala提出,而第一個(gè)真正研究斐波那契數(shù)列的是意大利數(shù)學(xué)家 Leonardo Fibonacci,需要的朋友可以參考下2019-07-07python中子類(lèi)與父類(lèi)的關(guān)系基礎(chǔ)知識(shí)點(diǎn)
在本篇文章里小編給大家整理的是一篇關(guān)于python中子類(lèi)與父類(lèi)的關(guān)系基礎(chǔ)知識(shí)點(diǎn)內(nèi)容,對(duì)此有興趣的朋友們可以學(xué)習(xí)下。2021-02-02python機(jī)器學(xué)習(xí)pytorch自定義數(shù)據(jù)加載器
這篇文章主要為大家介紹了python機(jī)器學(xué)習(xí)pytorch自定義數(shù)據(jù)加載器使用示例學(xué)習(xí),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10python實(shí)現(xiàn)可視化動(dòng)態(tài)CPU性能監(jiān)控
這篇文章主要為大家詳細(xì)介紹了python可視化動(dòng)態(tài)CPU性能監(jiān)控,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-06-06Python?Serial串口的簡(jiǎn)單數(shù)據(jù)收發(fā)方式
這篇文章主要介紹了Python?Serial串口的簡(jiǎn)單數(shù)據(jù)收發(fā)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09