Python根據(jù)字典值對(duì)字典進(jìn)行排序的三種方法實(shí)例
一、實(shí)際場(chǎng)景及解決思路
實(shí)際場(chǎng)景:比如某個(gè)班的數(shù)學(xué)成績(jī)以字典格式存儲(chǔ)為:
student_dict = {
'xiaoliang': 81,
'xiaowang' : 92,
'xiaoxin' : 99,
......
}
實(shí)際字典存儲(chǔ)是隨機(jī)排序的,本文給出根據(jù)每個(gè)學(xué)生的成績(jī)對(duì)學(xué)生字典格式數(shù)據(jù)進(jìn)行排序,并將排序結(jié)果返回給字典中的解決方法。
解決思路:將字典中的元素轉(zhuǎn)換為元組,使用內(nèi)置函數(shù)sorted排序。由于Python內(nèi)置方法sorted并不能直接對(duì)字典進(jìn)行操作,所以需要首先將字典格式數(shù)據(jù)轉(zhuǎn)換為元組列表數(shù)據(jù)格式,然后使用sorted進(jìn)行排序,常用的方法包括三種:
- 方法1:使用列表解析方法實(shí)現(xiàn)
- 方法2(推薦):使用
zip方法實(shí)現(xiàn) - 方法3(高級(jí)用法):傳遞
sorted函數(shù)的key參數(shù)
二、字典排序的三種實(shí)現(xiàn)方法
2.1 使用列表解析方法實(shí)現(xiàn)字典排序
方案1:使用列表解析方法實(shí)現(xiàn)
(1)使用列表解析方法將字典中的像轉(zhuǎn)化為
(value, key)的元組格式,然后使用sorted方法實(shí)現(xiàn)排序;
(2)注意:元組比較大小是根據(jù)第一個(gè)元素value決定的輸出的真假,當(dāng)?shù)谝粋€(gè)元素value相同時(shí)候,才比較第二個(gè),依次類(lèi)推。
Python代碼如下所示:
from random import randint
# 1.創(chuàng)建一個(gè)包含20個(gè)學(xué)生名及成績(jī)的字典創(chuàng)建方法
student_dict = {'student_%d' % i: randint(50, 100)
for i in range(1, 21)}
# 2.使用列表解析方法將學(xué)生字典轉(zhuǎn)換為(value, key)的元組格式
student_tuplelist = [(stu_value, stu_key) for stu_key, stu_value
in student_dict.items()]
# 查看以下轉(zhuǎn)換后的效果
print(student_tuplelist)
# 3.使用sorted函數(shù)對(duì)元組列表student_list由分?jǐn)?shù)高低進(jìn)行排序
student_tuplelist_sorted = sorted(student_tuplelist,
reverse=True)
# 輸出結(jié)果:
print(student_tuplelist_sorted)
代碼執(zhí)行結(jié)果如下圖所示:

2.2 使用zip方法實(shí)現(xiàn)字典排序
(1)使用
zip方法將字典中的像轉(zhuǎn)化為(value, key)的元組格式,然后使用sorted方法實(shí)現(xiàn)排序;
(2)注意zip的輸出為一個(gè)zip對(duì)象(zip object),需要使用列表構(gòu)造器list才能轉(zhuǎn)換為元組列表;
(3)結(jié)合下圖zip函數(shù)的功能,使用zip將學(xué)生字典轉(zhuǎn)換為元組列表的方法為:list(zip(student_dict.values(), student_dict.keys()))。

Python代碼如下所示:
from random import randint
# 1.創(chuàng)建一個(gè)包含20個(gè)學(xué)生名及成績(jī)的字典創(chuàng)建方法
student_dict = {'student_%d' % i: randint(50, 100)
for i in range(1, 21)}
# 2.使用zip方法將學(xué)生字典轉(zhuǎn)換為(value, key)的元組格式
student_tuplelist = list(zip(student_dict.values(),
student_dict.keys()))
# 查看以下轉(zhuǎn)換后的效果
print(student_tuplelist)
# 3.使用sorted函數(shù)對(duì)元組列表student_list由分?jǐn)?shù)高低進(jìn)行排序
student_tuplelist_sorted = sorted(student_tuplelist,
reverse=True)
# 輸出結(jié)果:
print(student_tuplelist_sorted)
2.3 使用傳遞sorted函數(shù)的key參數(shù)實(shí)現(xiàn)字典排序
(1)由于
sorted方法有一個(gè)key參數(shù),它可以指定排序?qū)ο笫前凑兆值淠念?lèi)元素(鍵值或者值)進(jìn)行排序;
(2)需要注意的是對(duì)于key參數(shù)我們需要使用lambda匿名函數(shù)作為迭代器key=lambda x: x[1],依次訪問(wèn)學(xué)生字典的值;sorted函數(shù)的學(xué)生字典傳入方法為student_dict.items()。
(3)使用sorted函數(shù)的key參數(shù)對(duì)字典數(shù)據(jù)進(jìn)行排序,代碼顯得更加簡(jiǎn)潔。
Python實(shí)現(xiàn)代碼如下所示:
from random import randint
# 1.創(chuàng)建一個(gè)包含20個(gè)學(xué)生名及成績(jī)的字典創(chuàng)建方法
student_dict = {'student_%d' % i: randint(50, 100)
for i in range(1, 21)}
# 2.傳遞`sorted`函數(shù)的`key`參數(shù)實(shí)現(xiàn)學(xué)生字典數(shù)據(jù)的排序
student_tuplelist_sorted = sorted(student_dict.items(),
key=lambda x: x[1], reverse=True)
# 3.輸出結(jié)果
print(student_tuplelist_sorted)

三、將sorted排序的列表返回給字典
上面三種方案對(duì)學(xué)生字典數(shù)據(jù)進(jìn)行排序后返回的是一個(gè)元素為元組的列表,而如果我們需要的還是字典格式,可以使用python的內(nèi)置函數(shù)enumerate實(shí)現(xiàn)。對(duì)返回的元組列表排序結(jié)果使用enumerate后的輸出為一個(gè)枚舉對(duì)象(enumerate object),結(jié)果如下圖所示:

這里需要使用列表生成器list(enumerate(student_tuplelist_sorted, 1))讀取其中的元素,其中參數(shù)1表示初始標(biāo)號(hào)為1,輸出結(jié)果如下圖所示:

由上圖可以看出,enumerate函數(shù)的輸出元組列表格式為(序號(hào), ('student_x', 考試分?jǐn)?shù)))。使用for循環(huán)可以依次讀取enumerate中的內(nèi)容,并重新構(gòu)建學(xué)生字典。代碼如下所示:
from random import randint
# 1.創(chuàng)建一個(gè)包含20個(gè)學(xué)生名及成績(jī)的字典創(chuàng)建方法
student_dict = {'student_%d' % i: randint(50, 100)
for i in range(1, 21)}
# 2.使用傳遞`sorted`函數(shù)的`key`參數(shù)的方法對(duì)字典進(jìn)行排序
student_tuplelist_sorted = sorted(student_dict.items(),
key=lambda x: x[1], reverse=True)
# 3.使用for循環(huán)結(jié)合內(nèi)置函數(shù)enumerate重新構(gòu)建排序后的字典:
student_dict_sorted = {}
for rank, (stu_key, stu_val) in enumerate(
student_tuplelist_sorted, 1):
# 重新構(gòu)造帶有排名的排序后的學(xué)生字典student_dict_sorted
student_dict_sorted[stu_key] = (rank, stu_val)
# 4.查看結(jié)果
print("帶有名次的排序后學(xué)生字典:", student_dict_sorted)
代碼執(zhí)行結(jié)果如下圖所示:

總結(jié)
到此這篇關(guān)于Python根據(jù)字典值對(duì)字典進(jìn)行排序的三種方法的文章就介紹到這了,更多相關(guān)Python根據(jù)字典值對(duì)字典排序內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python使用docx模塊讀寫(xiě)docx文件的方法與docx模塊常用方法詳解
這篇文章主要介紹了python使用docx模塊讀寫(xiě)docx文件的方法與docx模塊常用方法詳解,需要的朋友可以參考下2020-02-02
Python下載網(wǎng)絡(luò)小說(shuō)實(shí)例代碼
這篇文章主要介紹了Python下載網(wǎng)絡(luò)小說(shuō)實(shí)例代碼,分享了相關(guān)代碼示例,小編覺(jué)得還是挺不錯(cuò)的,具有一定借鑒價(jià)值,需要的朋友可以參考下2018-02-02
Python數(shù)值求解微分方程方法(歐拉法,隱式歐拉)
這篇文章主要介紹了Python數(shù)值求解微分方程方法(歐拉法,隱式歐拉),文章圍繞主題展開(kāi)詳細(xì)的內(nèi)介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-09-09
解決os.path.isdir() 判斷文件夾卻返回false的問(wèn)題
今天小編就為大家分享一篇解決os.path.isdir() 判斷文件夾卻返回false的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-11-11
超級(jí)好用的4個(gè)Python命令行可視化庫(kù)
通常大家都是在自己的電腦上跑程序,直接是可以可視化相應(yīng)的結(jié)果.如果是在服務(wù)器上的話(huà),使用終端,是不太方便查看結(jié)果. 今天,小F就給大家介紹4個(gè)可以在命令行中使用的Python庫(kù). 分別是Bashplotlib、tqdm、PrettyTable、Colorama,需要的朋友可以參考下2021-06-06

