python字典按照value排序方法
python中,我們可以對(duì)列表、字符串、元祖中的元素進(jìn)行排序,那對(duì)于字典中的元素可以排序嗎?其實(shí)對(duì)于字典本身我們無法進(jìn)行排序,但是我們可以對(duì)字典按值排序。本文介紹python中對(duì)字典按照value進(jìn)行排序的三種方法。
方法一:key使用lambda匿名函數(shù)取value進(jìn)行排序
dict= {'a':1,'b':4,'c':2}
sorted(dict.items(),key = lambda x:x[1],reverse = True)
方法二:使用operator的itemgetter進(jìn)行排序
test_data_6=sorted(dict_data.items(),key=operator.itemgetter(1)) test_data_7=sorted(dict_data.items(),key=operator.itemgetter(1),reverse=True) print(test_data_6) #[(8, 2), (10, 5), (7, 6), (6, 9), (3, 11)] print(test_data_7) #[(3, 11), (6, 9), (7, 6), (10, 5), (8, 2)]
方法三:key和value分裝成元祖,再進(jìn)行排序
f = zip(d.keys(), d.values()) c = sorted(f) print(c)
字典按value排序內(nèi)容擴(kuò)展:
保存為字典后,按字典的value值大小排序,這個(gè)才是本題的難點(diǎn),由于dict是無序的,所以只能用list去排序,把dict的key和value保存為tuplue對(duì)象
# 對(duì)字典按value排序 a = sorted(d.items(), key=lambda x: x[1], reverse=True) print(a)
參考代碼:
# coding:utf-8
# 作者:上海-悠悠
a = ["a", "b", "a", "c", "a", "c", "b", "d", "e", "c", "a", "c"]
# set集合去重
duixiang = set(a) # 先去重,取出計(jì)數(shù)對(duì)象
# 保存為dict,一一對(duì)應(yīng)
d = {}
for i in duixiang:
d[i] = a.count(i)
# 對(duì)字典按value排序
a = sorted(d.items(), key=lambda x: x[1], reverse=True)
print(a)
到此這篇關(guān)于python字典按照value排序方法的文章就介紹到這了,更多相關(guān)python中字典如何按照value排序內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python??處理?Pandas?DataFrame?中的行和列
這篇文章主要介紹了Python處理Pandas?DataFrame中的行和列,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-09-09
python中__new__和__init__的實(shí)現(xiàn)
在Python中,每個(gè)對(duì)象都有兩個(gè)特殊的方法__new__和__init__,本文主要介紹了python中__new__和__init__的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2024-05-05
神經(jīng)網(wǎng)絡(luò)(BP)算法Python實(shí)現(xiàn)及應(yīng)用
這篇文章主要為大家詳細(xì)介紹了Python實(shí)現(xiàn)神經(jīng)網(wǎng)絡(luò)(BP)算法及簡單應(yīng)用,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-04-04
如何使用 Flask 做一個(gè)評(píng)論系統(tǒng)
這篇文章主要介紹了如何使用 Flask 做一個(gè)評(píng)論系統(tǒng),幫助大家更好的理解和使用flask框架進(jìn)行python web開發(fā),感興趣的朋友可以了解下2020-11-11

