資訊內容
Python介紹 list.sort方法和內置函數sorted

相關免費學習推薦:python視頻教程YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
Python列表排序 list.sort方法和內置函數sortedYiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
很多時候我們獲取到一個列表后,這個列表并不滿足我們的需求,我們需要的是一個有特殊順序的列表.YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
這時候就可以使用list.sort方法和內置函數sorted,本文就是介紹list.sort方法和sorted內置函數的使用方法和區別.YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
一、list.sort方法YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
list.sort方法會就地排序列表,也就是說不會把原列表復制一份。這也是這個方法的返回值是None的原因,提醒您本方法不會新建一個列表。YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
在這種情況下返回None其實是Python的一個慣例:如果一個函數或者方法對對象進行的是就地改動,那它就應該返回 None,好讓調用者知道傳入的參數發生了變動,而且并未產生新的對象。YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
來看一下代碼:YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
# coding=utf-8 list_a = [1, 2, 8, 3, 7, 9, 5, 7] # sort()方法沒有返回值 list_b = list_a.sort() print("list_a: ", list_a) print('list_b: ', list_b)運行結果:YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
list_a: [1, 2, 3, 5, 7, 7, 8, 9] list_b: None用返回None來表示就地改動這個慣例有個弊端,那就是調用者無法將其串聯起來。而返回一個新對象的方法則正好相反,它們可以鏈式調用,從而形成連貫接口。YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
二、sorted內置函數YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
與 list.sort 相反,內置函數sorted會新建一個列表作為返回值。YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
這個方法可以接受任何形式的可迭代對象作為參數,甚至包括不可變序列或生成器,而不管sorted接受的是怎樣的參數,它**后都會返回一個列表。YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
代碼示例:YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
list_c = [1, 2, 8, 3, 7, 9, 5, 7] # sorted內置函數會返回一個排序后的新列表 list_d = sorted(list_c) print("list_c: ", list_c) print('list_d: ', list_d)運行結果:YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
list_c: [1, 2, 8, 3, 7, 9, 5, 7] list_d: [1, 2, 3, 5, 7, 7, 8, 9]可以看到,使用內置函數sorted時,返回了一個新的列表,而原列表沒有發生改變。YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
這有兩種好處:YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
1.如果我們即需要使用原列表,也需要使用排序后的列表,或者說我們要將一個非列表的可迭代對象排序成列表,sorted都可以做到YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
2.有返回值時,我們可以進行鏈式調用YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
# 可以對非列表的可迭代對象排序生成列表 str_e = 'python' list_e = sorted(str_e) print(list_e) # 鏈式調用 str_f = '-'.join(sorted(str_e)).upper().split('-') print(str_f)運行結果:YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
['h', 'n', 'o', 'p', 't', 'y'] ['H', 'N', 'O', 'P', 'T', 'Y']三、關鍵字參數key和reverseYiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
不管是 list.sort 方法還是 sorted 函數,都有兩個可選的關鍵字參數:YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
key:
接收一個只有一個參數的函數,這個函數會被用在序列里的每一個元素上,所產生的結果將是排序算法依賴的對比關鍵字。YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
比如說,在對一些字符串排序時,可以用 key=str.lower 來實現忽略大小寫的排序,或者是用 key=len 進行基于字符串長度的排序。key的默認值是恒等函數,也就是默認用元素自己的值來排序。YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
reverse:YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
如果被設定為 True,被排序的序列里的元素會以降序輸出(也就是說把**大值當作**小值來排序),reverse的默認值是 False.YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
phone = ('HUAWEI', 'OPPO', 'MI', 'MEIZU', 'VIVO') # 按長度進行排序 phone_list = sorted(phone, key=len) print(phone_list) phone_list_re = sorted(phone, key=len, reverse=True) print(phone_list_re)運行結果:YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
['MI', 'OPPO', 'VIVO', 'MEIZU', 'HUAWEI'] ['HUAWEI', 'MEIZU', 'OPPO', 'VIVO', 'MI']上面的代碼中,第一次排序新建了一個按照長度排序的字符串列表。第二次排序是將按長度排序由升序變成了降序。YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
細心的您應該可以發現,第二次的結果并不是第一次排序的結果的完全翻轉。YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
OPPO和VIVO的長度都是4,reverse=True后,它們的相對位置跟第一次排序是一樣的。這是什么原因呢?YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
sorted和list.sort背后的排序算法都是Timsort,它是一種自適應算法,會根據原始數據的順序特點交替使用插入排序和歸并排
序,以達到**佳效率。YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
Python的排序算法Timsort是穩定的(知道這一點就可以了),意思是就算兩個元素比不出大小,在每次排序的結果里它們的相對位置是固定的。YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
因為用到的排序算法是穩定的,也就是說在長度一樣時,OPPO和VIVO的相對位置不會改變。
關于list.sort()方法和sorted內置函數的使用,現在已經掌握了~YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
相關免費學習推薦:python教程(視頻)YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺
以上就是Python介紹 list.sort方法和內置函數sorted的詳細內容,更多請關注少兒編程網其它相關文章!YiP少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

- 上一篇
認識Python對象自省機制
簡介相關免費學習推薦:python視頻教程自省是通過一定的機制查詢到對象的內部結構。Python中比較常見的自省(introspection)機制(函數用法)有:dir(),type(),hasattr(),isinstance(),通過這些函數,我們能夠在程序運行時得知對象的類型,判斷對象是否存在某個
- 下一篇
python如何保留2位小數
簡介python保留2位小數的方法:首先打開編輯器pycharm,新建變量a;然后利用round函數將a的值保留2位數,并打印結果;接著在窗口中選擇run;最后最后運行這個程序即可。本教程操作環境:windows7系統、pycharm2020版,DELLG3電腦,該方法適用于所有