在Python中字典按值排序的實(shí)現(xiàn)方法
一、sorted高階函數(shù)
這種方法更為簡潔,更為推薦。
d={'a':1,'c':3,'b':2} # 首先建一個(gè)字典d #d.items()返回的是: dict_items([('a', 1), ('c', 3), ('b', 2)]) d_order=sorted(d.items(),key=lambda x:x[1],reverse=False) # 按字典集合中,每一個(gè)元組的第二個(gè)元素排列。 # x相當(dāng)于字典集合中遍歷出來的一個(gè)元組。 print(d_order) # 得到: [('a', 1), ('b', 2), ('c', 3)]
下面是sorted排序方法的詳細(xì)解釋:
1. sorted高階函數(shù)語法格式: sorted(可迭代對象,key=函數(shù)名,reverse=False/True)
作用:從可迭代對象中,依次取出一個(gè)元素,該元素再按照key規(guī)定的排列依據(jù)排序。
可迭代對象:即可依次取值的對象,例如:集合,序列(列表,字符串,元組),字典等。
key : 是列表排列的依據(jù),一般可以自定義一個(gè)函數(shù)返回排序的依據(jù),再把函數(shù)名綁定給key。
reverse : 譯為反轉(zhuǎn),reverse默認(rèn)等于False,從小到大排序。等于True時(shí),從大到小排序。
2. 匿名函數(shù)lambda的格式: 函數(shù)名 = lambda [形參1,形參2,...] :
,返回操作語句塊產(chǎn)生的結(jié)果并綁定給函數(shù)名。
例如: key=lambda x : x[1]
x:相當(dāng)于字典集合中的一個(gè)元組, 例:dict_items([('a', 1), ('c', 3), ('b', 2)])中的('a', 1)或('c', 3)或('b', 2)
x[1]: 返回x中的第二個(gè)元素,即鍵值對元組中的值。dict_items([('a', 1), ('c', 3), ('b', 2)])中的1或2或3
注意:
(1) sorted函數(shù)中的可迭代對象不要用字典d,那樣只能迭代出的字典d的鍵。要用d.items()才可迭代出字典的鍵值對。
例:不能用 d_order=sorted(d,key=lambda x:x[1],reverse=False)
要用 d_order=sorted(d.items(),key=lambda x:x[1],reverse=False)
(2) sorted函數(shù)排好序后,要綁定一個(gè)對象(賦值),例:d_order=sorted(d.items(),key=lambda x:x[1],reverse=False).
因?yàn)樽值涫菬o序類型,用sorted函數(shù)排好序后不綁定d_order,字典會自動打亂順序。
二、列表的.sort()方法
Python中的字典是無序類型,沒有自己的排序方法。但可以用列表的.sort()方法來進(jìn)行排序。
我們首先要把字典轉(zhuǎn)換為列表,再進(jìn)行排序。
例子:
d={'a':1,'c':3,'b':2} # 首先建一個(gè)字典d d.items() # 得到: dict_items([('a', 1), ('c', 3), ('b', 2)]) L=list(d.items()) # 得到列表: L=[('a', 1), ('c', 3), ('b', 2)] L.sort(key=lambda x:x[1],reverse=False) # 按列表中,每一個(gè)元組的第二個(gè)元素從小到大排序。 # x代表從L中遍歷出的一個(gè)元組 print(L) # 得到: [('a', 1), ('b', 2), ('c', 3)]
注意:
1.上面的例子中最要的一步就是: L=list(d.items()), 即: L = list(dict_items([('a', 1), ('c', 3), ('b', 2)])
用list()列表構(gòu)造函數(shù),將L= dict_items([('a', 1), ('c', 3), ('b', 2)])
轉(zhuǎn)變?yōu)榱斜?,得到列? L=[('a', 1), ('c', 3), ('b', 2)]
。
ps: 今天早上我折騰了好久才發(fā)現(xiàn),list()構(gòu)造函數(shù)竟然可以把 d.items()產(chǎn)生的dict_items鍵值對集合類型,直接變成列表,簡直NB??!
2.再簡單說一下列表的L.sort()方法: L.sort(key=函數(shù)名,reverse=False/True)
L.sort():會自動遍歷列表中的元素,即依次取出一個(gè)元素。再以key綁定的函數(shù)為依據(jù)排序。
例如: L.sort(key=lambda x:x[1],reverse=False) #L=[('a', 1), ('c', 3), ('b', 2)]
從列表L中取出第一個(gè)元素('a', 1)元組,以元組的第二個(gè)元素'1'為排序依據(jù),
再依次從列表中依次取出第二,第三,...個(gè)元素確定排序依據(jù),
最后reverse=False,按從小到大的順序排列。
注: L.sort()內(nèi)部還有其他參數(shù),感興趣的小伙伴可以用度娘搜一下。
三、擴(kuò)展:
其實(shí)小c君是在用jieba庫進(jìn)行文本詞頻統(tǒng)計(jì)時(shí),才遇到了給字典排序的這個(gè)問題。
小伙伴們感興趣的話可以看一下下面的代碼,也可以自己找個(gè)文本試一下,非常有趣。
import jieba with open("天龍八部-網(wǎng)絡(luò)版.txt",'r',encoding='utf-8') as f: txt=f.read() words=jieba.lcut(txt) d={} for word in words: d[word]=d.get(word,0)+1 del d[' '] del d['\n'] with open("天龍八部-詞語統(tǒng)計(jì).txt",'w',encoding='utf-8') as f2: d=sorted(d.items(),key=lambda x:x[1],reverse=True) for x,y in d: f2.write("{}:{}\n".format(x,y))
注:還可以優(yōu)化代碼,進(jìn)行文本降噪。
四、后記:
今天折騰了一天,終于把字典排序的問題解決了。
到此這篇關(guān)于在Python中字典按值排序的實(shí)現(xiàn)方法的文章就介紹到這了,更多相關(guān)Python 字典按值排序內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
從零學(xué)Python之入門(五)縮進(jìn)和選擇
空白在Python中是重要的。事實(shí)上行首的空白是重要的。它稱為縮進(jìn)。在邏輯行首的空白(空格和制表符)用來決定邏輯行的縮進(jìn)層次,從而用來決定語句的分組。2014-05-05Python腳本按照當(dāng)前日期創(chuàng)建多級目錄
今天小編就為大家分享一篇關(guān)于Python腳本按照當(dāng)前日期創(chuàng)建多級目錄,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2019-03-03Python?Matplotlib繪制箱線圖boxplot()函數(shù)詳解
箱線圖一般用來展現(xiàn)數(shù)據(jù)的分布(如上下四分位值、中位數(shù)等),同時(shí)也可以用箱線圖來反映數(shù)據(jù)的異常情況,下面這篇文章主要給大家介紹了關(guān)于Python?Matplotlib繪制箱線圖boxplot()函數(shù)的相關(guān)資料,需要的朋友可以參考下2022-07-07Python 數(shù)據(jù)結(jié)構(gòu)之旋轉(zhuǎn)鏈表
這篇文章主要介紹了Python 數(shù)據(jù)結(jié)構(gòu)之旋轉(zhuǎn)鏈表的相關(guān)資料,需要的朋友可以參考下2017-02-02Python?matplotlib中plt.plot()函數(shù)的顏色參數(shù)設(shè)置及可以直接運(yùn)行的程序代碼
在數(shù)據(jù)可視化中matplotlib.pyplot模塊的plot函數(shù)是一個(gè)非常重要且常用的工具,用于繪制2D圖形,這篇文章主要給大家介紹了關(guān)于Python?matplotlib中plt.plot()函數(shù)的顏色參數(shù)設(shè)置及可以直接運(yùn)行的程序代碼,需要的朋友可以參考下2024-03-03