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

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

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

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

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

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

總結(jié)
到此這篇關于Python根據(jù)字典值對字典進行排序的三種方法的文章就介紹到這了,更多相關Python根據(jù)字典值對字典排序內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Selenium中免登錄的實現(xiàn)方法option詳解
在selenium中有很多種可以實現(xiàn)網(wǎng)站的免登錄,option就是其中的一種做法,這篇文章主要介紹了Selenium中免登錄的實現(xiàn)方法option,需要的朋友可以參考下2022-12-12
python?中defaultdict()對字典進行初始化的用法介紹
這篇文章主要介紹了python?中defaultdict()對字典進行初始化,一般情況下,在使用字典時,先定義一個空字典(如dict_a?=?{}),然后往字典中添加元素只需要?dict_a[key]?=?value即可,本文通過實例代碼介紹具體用法,需要的朋友可以參考下2022-07-07

