久久国产成人av_抖音国产毛片_a片网站免费观看_A片无码播放手机在线观看,色五月在线观看,亚洲精品m在线观看,女人自慰的免费网址,悠悠在线观看精品视频,一级日本片免费的,亚洲精品久,国产精品成人久久久久久久

分享

在Python中,字典按值排序

 大傻子的文淵閣 2020-01-02

  我們可以用sorted高階函數或者用列表的.sort()方法,。

目錄

在Python中,,字典按值排序

一、sorted高階函數

二、列表的.sort()方法 

三,、擴展

四,、后記


 

一、sorted高階函數

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

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

下面是sorted排序方法的詳細解釋:

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

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

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

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

     reverse : 譯為反轉,reverse默認等于False,,從小到大排序,。等于True時,從大到小排序,。

 

2. 匿名函數lambda的格式:    函數名 = lambda  [形參1,形參2,...] :  ,返回操作語句塊產生的結果并綁定給函數名,。

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

            x:相當于字典集合中的一個元組,, 例: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函數中的可迭代對象不要用字典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函數排好序后,,要綁定一個對象(賦值),例:d_order=sorted(d.items(),key=lambda x:x[1],reverse=False).

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

 

 

二,、列表的.sort()方法 

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

我們首先要把字典轉換為列表,,再進行排序,。

 例子:

  1. d={'a':1,'c':3,'b':2} # 首先建一個字典d
  2. d.items() # 得到: dict_items([('a', 1), ('c', 3), ('b', 2)])
  3. L=list(d.items()) # 得到列表: L=[('a', 1), ('c', 3), ('b', 2)]
  4. L.sort(key=lambda x:x[1],reverse=False) # 按列表中,每一個元組的第二個元素從小到大排序,。
  5. # x代表從L中遍歷出的一個元組
  6. print(L) # 得到:  [('a', 1), ('b', 2), ('c', 3)]

 注意:

 1.上面的例子中最要的一步就是:  L=list(d.items()),  即: L = list(dict_items([('a', 1), ('c', 3), ('b', 2)])

      用list()列表構造函數,,將L= dict_items([('a', 1), ('c', 3), ('b', 2)]) 轉變?yōu)榱斜恚玫搅斜?  L=[('a', 1), ('c', 3), ('b', 2)] ,。

      ps: 今天早上我折騰了好久才發(fā)現,,list()構造函數竟然可以把 d.items()產生的dict_items鍵值對集合類型,直接變成列表,,簡直NB?。?/p>

 2.再簡單說一下列表的L.sort()方法:  L.sort(key=函數名,reverse=False/True)

     L.sort():會自動遍歷列表中的元素,,即依次取出一個元素,。再以key綁定的函數為依據排序。

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

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

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

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

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

 

三、擴展:

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

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

  1. import jieba
  2. with open("天龍八部-網絡版.txt",'r',encoding='utf-8') as f:
  3. txt=f.read()
  4. words=jieba.lcut(txt)
  5. d={}
  6. for word in words:
  7. d[word]=d.get(word,0)+1
  8. del d[' ']
  9. del d['\n']
  10. with open("天龍八部-詞語統(tǒng)計.txt",'w',encoding='utf-8') as f2:
  11. d=sorted(d.items(),key=lambda x:x[1],reverse=True)
  12. for x,y in d:
  13. f2.write("{}:{}\n".format(x,y))

注:還可以優(yōu)化代碼,進行文本降噪,。

 

四,、后記:

今天折騰了一天,終于把字典排序的問題解決了,。

小c君的編程之路才剛開始,,希望自己將來無論遇到何種挫折都不要輕言放棄,堅持下去,

多掙點錢,,

娶新垣結衣,。

 

    本站是提供個人知識管理的網絡存儲空間,所有內容均由用戶發(fā)布,,不代表本站觀點,。請注意甄別內容中的聯(lián)系方式、誘導購買等信息,,謹防詐騙,。如發(fā)現有害或侵權內容,請點擊一鍵舉報,。
    轉藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多