如何根據(jù)字典中值的大小,對(duì)字典中的項(xiàng)排序

實(shí)際案例

某班英語(yǔ)成績(jī)以字典形式存儲(chǔ)為{'Li':79, 'Jim':88, 'Lucy':92, ...},根據(jù)成績(jī)高低,計(jì)算學(xué)生排名。

這里我們將利用內(nèi)置函數(shù)sorted對(duì)學(xué)生的英語(yǔ)成績(jī)排名。

方法一:

首先,我們利用zip()將字典轉(zhuǎn)化為元組;然后,我們調(diào)用sorted函數(shù)對(duì)元組進(jìn)行排序,代碼如下:

# -*- coding: utf-8 -*-

from random import randint

student = {k: randint(0, 100) for k in "qazwsx"}

# 將字典轉(zhuǎn)為元組
stu = zip(student.values(), student.keys())

print sorted(stu)

其運(yùn)行結(jié)果如下:
[(1, 'x'), (3, 's'), (40, 'w'), (41, 'a'), (78, 'q'), (90, 'z')]

方法二:

我們利用sorted函數(shù)中key這個(gè)參數(shù),對(duì)字典進(jìn)行排序。看到這里有沒(méi)有想起我們上一篇文章中根據(jù)值對(duì)字典的元素進(jìn)行從大到小的排序呢?不錯(cuò),這里我們將使用上一篇文章所使用的方法對(duì)字典排序,代碼如下:

# -*- coding: utf-8 -*-

from random import randint

student = {k: randint(0, 100) for k in "qazwsx"}

print sorted(student.items(), key=lambda v: v[1])

其運(yùn)行結(jié)果如下:
[('x', 1), ('s', 3), ('w', 40), ('a', 41), ('q', 78), ('z', 90)]

參數(shù)說(shuō)明:
  • items()可將字典中的每個(gè)鍵值對(duì)轉(zhuǎn)換成一個(gè)一個(gè)的元組,并將這些元組組合成一個(gè)list。
  • key值的傳入,我們這里使用匿名函數(shù)lambda,利用這個(gè)函數(shù),我們可以對(duì)字典進(jìn)行按鍵、按值排序,即v[0]則為按鍵排序,v[1]則為按值排序。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容