溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Python中的字典如何實現(xiàn)按值排序

發(fā)布時間:2020-11-16 15:30:29 來源:億速云 閱讀:525 作者:Leah 欄目:開發(fā)技術(shù)

這篇文章將為大家詳細(xì)講解有關(guān)Python中的字典如何實現(xiàn)按值排序,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。

一、sorted高階函數(shù)

  這種方法更為簡潔,更為推薦。

d={'a':1,'c':3,'b':2}  # 首先建一個字典d

#d.items()返回的是: dict_items([('a', 1), ('c', 3), ('b', 2)])

d_order=sorted(d.items(),key=lambda x:x[1],reverse=False) # 按字典集合中,每一個元組的第二個元素排列。
                              # x相當(dāng)于字典集合中遍歷出來的一個元組。
print(d_order)   # 得到: [('a', 1), ('b', 2), ('c', 3)]

下面是sorted排序方法的詳細(xì)解釋:

1. sorted高階函數(shù)語法格式:  sorted(可迭代對象,key=函數(shù)名,reverse=False/True)

     作用:從可迭代對象中,依次取出一個元素,該元素再按照key規(guī)定的排列依據(jù)排序。

     可迭代對象:即可依次取值的對象,例如:集合,序列(列表,字符串,元組),字典等。

     key : 是列表排列的依據(jù),一般可以自定義一個函數(shù)返回排序的依據(jù),再把函數(shù)名綁定給key。

     reverse : 譯為反轉(zhuǎn),reverse默認(rèn)等于False,從小到大排序。等于True時,從大到小排序。

2. 匿名函數(shù)lambda的格式:    函數(shù)名 = lambda  [形參1,形參2,...] :  ,返回操作語句塊產(chǎn)生的結(jié)果并綁定給函數(shù)名。

例如: key=lambda x : x[1]      

            x:相當(dāng)于字典集合中的一個元組, 例:dict_items([('a', 1), ('c', 3), ('b', 2)])中的('a', 1)或('c', 3)或('b', 2)

            x[1]: 返回x中的第二個元素,即鍵值對元組中的值。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ù)排好序后,要綁定一個對象(賦值),例:d_order=sorted(d.items(),key=lambda x:x[1],reverse=False).

     因為字典是無序類型,用sorted函數(shù)排好序后不綁定d_order,字典會自動打亂順序。

二、列表的.sort()方法

Python中的字典是無序類型,沒有自己的排序方法。但可以用列表的.sort()方法來進(jìn)行排序。

我們首先要把字典轉(zhuǎn)換為列表,再進(jìn)行排序。

 例子:

d={'a':1,'c':3,'b':2}  # 首先建一個字典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) # 按列表中,每一個元組的第二個元素從小到大排序。
                     # x代表從L中遍歷出的一個元組

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():會自動遍歷列表中的元素,即依次取出一個元素。再以key綁定的函數(shù)為依據(jù)排序。

     例如: L.sort(key=lambda x:x[1],reverse=False)       #L=[('a', 1), ('c', 3), ('b', 2)]

                 從列表L中取出第一個元素('a', 1)元組,以元組的第二個元素'1'為排序依據(jù),

                 再依次從列表中依次取出第二,第三,...個元素確定排序依據(jù),

                 最后reverse=False,按從小到大的順序排列。

     注: L.sort()內(nèi)部還有其他參數(shù),感興趣的小伙伴可以用度娘搜一下。

三、擴(kuò)展:

其實小c君是在用jieba庫進(jìn)行文本詞頻統(tǒng)計時,才遇到了給字典排序的這個問題。

小伙伴們感興趣的話可以看一下下面的代碼,也可以自己找個文本試一下,非常有趣。

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)計.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中的字典如何實現(xiàn)按值排序就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI