Python中Sorted()函數(shù)的key參數(shù)使用方法詳解
一、sorted函數(shù)
sorted() 函數(shù)是 Python 內(nèi)置的一種排序函數(shù),它可以對序列進(jìn)行排序,并且返回排序后的結(jié)果。該函數(shù)的語法格式如下:
sorted(iterable, /, *, key=None, reverse=False)
其中,iterable 是待排序的元素集合,可以是列表、元組、字典等可迭代對象。key 和 reverse 是可選參數(shù)。
- key 參數(shù)用于指定一個函數(shù),該函數(shù)將應(yīng)用于待排序的每個元素上,獲取用于排序的關(guān)鍵字(key)。具體來說,key 參數(shù)需要傳遞一個函數(shù),它會取待排序元素作為輸入,并返回一個用于定制排序的關(guān)鍵字。默認(rèn)為 None,表示直接比較待排序元素本身進(jìn)行排序。
- reverse 參數(shù)是一個布爾值,用于決定排序順序。默認(rèn)值為 False,表示升序排序。如果將該參數(shù)指定為 True,則表示降序排序。
下面舉一個例子,說明在實際應(yīng)用中 sorted() 函數(shù)的用法:
from collections import namedtuple
# 構(gòu)造一個命名元組類型
Person = namedtuple('Person', ['name', 'age', 'gender'])
# 創(chuàng)建一個 Person 的列表
people = [
Person('Alice', 22, 'F'),
Person('Bob', 35, 'M'),
Person('Charlie', 28, 'M'),
Person('David', 28, 'M'),
Person('Eva', 21, 'F')
]
# 按年齡進(jìn)行升序排序
people_by_age = sorted(people, key=lambda p: p.age)
print(people_by_age)
# 按姓名的首字母進(jìn)行降序排序
people_by_first_letter = sorted(people, key=lambda p: p.name[0], reverse=True)
print(people_by_first_letter)
===結(jié)果===
[Person(name='Eva', age=21, gender='F'), Person(name='Alice', age=22, gender='F'), Person(name='Charlie', age=28, gender='M'), Person(name='David', age=28, gender='M'), Person(name='Bob', age=35, gender='M')]
[Person(name='Eva', age=21, gender='F'), Person(name='David', age=28, gender='M'), Person(name='Charlie', age=28, gender='M'), Person(name='Bob', age=35, gender='M'), Person(name='Alice', age=22, gender='F')]
在上述代碼中,我們使用了 namedtuple 來定義了一個名為 Person 的命名元組類型,并創(chuàng)建了一個 people 列表來保存多個 Person 的實例。
我們使用 sorted() 函數(shù)對 people 列表進(jìn)行了升序和降序排序。升序排序是通過 key 參數(shù)指定了按照 Person 對象的 age 屬性進(jìn)行排序,而降序排序是通過 key 參數(shù)指定了按照 Person 對象的 name 屬性的第一個字母的 ASCII 值進(jìn)行排序。
當(dāng)需要對復(fù)雜的數(shù)據(jù)結(jié)構(gòu)進(jìn)行排序時,我們經(jīng)常需要自定義排序規(guī)則。此時,我們可以通過將自定義的函數(shù)作為 key 參數(shù)賦值,來實現(xiàn)對數(shù)據(jù)結(jié)構(gòu)按照任意排序規(guī)則進(jìn)行排序。
下面就給出一個示例,其中 key 參數(shù)通過一個自定義的函數(shù)實現(xiàn)對一個包含學(xué)生信息的列表進(jìn)行按照成績降序排序:
# 定義一個包含學(xué)生信息的列表
students = [('Alice', 95), ('Bob', 83), ('Charlie', 72), ('David', 90), ('Eva', 87)]
# 使用一個自定義的函數(shù),對學(xué)生信息按照成績降序排序
def sort_by_score(student):
return student[1]
students_sorted_by_score = sorted(students, key=sort_by_score, reverse=True)
print(students_sorted_by_score)
===輸出結(jié)果如下所示:===
[('Alice', 95), ('David', 90), ('Eva', 87), ('Bob', 83), ('Charlie', 72)]
在上述代碼中,我們首先定義了一個包含多個學(xué)生信息的列表 students,每個學(xué)生信息包含了姓名和成績兩個元素。接下來,我們定義了一個自定義函數(shù) sort_by_score,該函數(shù)的輸入?yún)?shù)是一個學(xué)生信息,我們將該學(xué)生信息的成績作為排序的關(guān)鍵字。
通過將 sort_by_score 函數(shù)賦值給 sorted() 函數(shù)中的 key 參數(shù),我們就實現(xiàn)了對學(xué)生列表按照學(xué)生成績進(jìn)行降序排序的目的。
總結(jié)
到此這篇關(guān)于Python中Sorted()函數(shù)的key參數(shù)使用方法的文章就介紹到這了,更多相關(guān)Python Sorted()函數(shù)key參數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python標(biāo)準(zhǔn)庫shutil模塊使用方法解析
這篇文章主要介紹了Python標(biāo)準(zhǔn)庫shutil模塊使用方法解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-03-03
Python機(jī)器學(xué)習(xí)算法之決策樹算法的實現(xiàn)與優(yōu)缺點
決策樹(Decision Tree)是一種基本的分類與回歸方法,這篇文章主要給大家介紹了關(guān)于Python機(jī)器學(xué)習(xí)算法之決策樹算法實現(xiàn)與優(yōu)缺點的相關(guān)資料,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05
Python淘寶或京東等秒殺搶購腳本實現(xiàn)(秒殺腳本)
本篇文章主要介紹了Python 通過selenium實現(xiàn)毫秒級自動搶購的示例代碼,通過掃碼登錄即可自動完成一系列操作,搶購時間精確至毫秒,可搶加購物車等待時間結(jié)算的,也可以搶聚劃算、火車票等的商品,感興趣的朋友跟隨小編一起看看吧2022-10-10

