91aaa在线国内观看,亚洲AV午夜福利精品一区二区,久久偷拍人视频,久久播这里有免费视播

<strong id="fvuar"></strong>

  • <sub id="fvuar"><dl id="fvuar"><em id="fvuar"></em></dl></sub>

    1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

      手機(jī)站
      千鋒教育

      千鋒學(xué)習(xí)站 | 隨時隨地免費(fèi)學(xué)

      千鋒教育

      掃一掃進(jìn)入千鋒手機(jī)站

      領(lǐng)取全套視頻
      千鋒教育

      關(guān)注千鋒學(xué)習(xí)站小程序
      隨時隨地免費(fèi)學(xué)習(xí)課程

      當(dāng)前位置:首頁  >  技術(shù)干貨  > Python的字典排序

      Python的字典排序

      來源:千鋒教育
      發(fā)布人:xqq
      時間: 2023-11-07 02:27:55 1699295275

      字典是Python語言中的一種數(shù)據(jù)結(jié)構(gòu),每一個字典元素是由一對key-value組成的。而字典的key和value分別以集合(Set)形似組織,以便快速查詢。集合的存儲形似通常是樹的結(jié)構(gòu),所以搜索非???。我們可以單獨(dú)通過字典的keys方法和values方法獲取鍵集合和值集合的可迭代對象,代碼如下:

      x={'x':20,'a':12,'b':5}

      print(x.keys())

      print(x.values())

      執(zhí)行這段代碼,會輸出如下的內(nèi)容:

      dict_keys(['x','a','b'])

      dict_values([20,12,5])

      PS:dict_keys和dict_values是Python的兩個內(nèi)部類,他們都采用了樹的結(jié)構(gòu)對數(shù)據(jù)進(jìn)行組織?,F(xiàn)在的問題是,集合是無序的(因?yàn)槭且詷錉罱Y(jié)構(gòu)存儲的),但由于某些要求,我們期望得到有序的鍵值,這就引出了下面的幾個問題:

      Q1:集合可以排序嗎?

      Q2:排序后,可以獲取成對的key-value嗎?

      Q3:除了按鍵值排序,可以按值排序嗎?

      為了回答這幾個問題,請繼續(xù)看下面的內(nèi)容。

      1.集合可以排序嗎?

      這個問題的答案是:No。既然稱為集合,由于數(shù)據(jù)存儲形式的原因,肯定是無序的,但我們可以做一個折中的處理。既然集合不能排序,那么可以將集合中的數(shù)據(jù)排序后,放到一個可以排序的數(shù)據(jù)結(jié)構(gòu)(例如,列表)里,這樣可以在一定程度上解決我們的問題。看下面的代碼:

      x={'x':20,'a':12,'b':5}

      keys=sorted(x.keys())

      values=sorted(x.values())

      print(type(keys))

      print(type(values))

      print(keys)

      print(values)

      在這段代碼中,使用了sorted函數(shù),該函數(shù)可以用于對序列進(jìn)行排序,并將排序結(jié)果放到一個列表中,最后返回這個列表,所以執(zhí)行這段代碼,會輸出如下的內(nèi)容:

      ['a','b','x']

      [5,12,20]

      現(xiàn)在我們的第一個問題解決了,使用sorted函數(shù),將集合按升序排列,并以列表形式體現(xiàn)。如果想降序排列,那么需要將reverse參數(shù)設(shè)置為True,代碼如下:

      keys=sorted(x.keys(),reverse=True)

      values=sorted(x.values(),reverse=True)

      2.排序后,可以獲取成對的key-value嗎?

      現(xiàn)在來解決第2個問題。本文討論的是字典,所以即使對key和value排序,也不是我們期望的,我們期望的是得到字典中的key-value對,而且是已經(jīng)排序好的key-value對。這個問題也非常好解決,既然已經(jīng)得到了排好序的key,那么就利用key從字典中獲得對應(yīng)的value,這樣就可以組成一對key-value了,代碼如下:

      x={'x':20,'a':12,'b':5}

      keys=sorted(x.keys())

      forkeyinkeys:

      print(f"{key}:{x[key]}")

      執(zhí)行這段代碼,會輸出如下的內(nèi)容:

      x:20

      b:5

      a:12

      很明顯,輸出的key-value對是按key升序排列的。

      3.除了按鍵值排序,可以按值排序嗎?

      那值排序是沒問題的,但排好序的值是沒什么用的。因?yàn)樽值洳⒉荒芡ㄟ^value反向獲取key。所以通過前面的方法只能獲取排好序的值。所以需要為sorted函數(shù)的key參數(shù),該參數(shù)用于指定使用key還是value進(jìn)行排序。如果使用的是Python3.7或以上版本??梢詾閗ey參數(shù)值指定lambda表達(dá)式,代碼如下:

      y1={k:vfork,vinsorted(x.items(),key=lambdaitem:item[1])}

      print(y1)

      #按值降序排列

      y2={k:vfork,vinsorted(x.items(),key=lambdaitem:item[1],reverse=True)}

      print(y2)

      這段代碼使用了for-in表達(dá)式生成了字典,其中x是待排序的字典。items獲取了key-value對。而lambda表達(dá)式的item就是當(dāng)前的key-value對。item[0]表示key,item[1]表示value,所以使用item[1],就表示按value排序,而使用item[0],就是按key排序。

      執(zhí)行這段代碼,會輸出如下的結(jié)果:

      {'b':5,'a':12,'x':20}

      {'x':20,'a':12,'b':5}

      如果不想使用for-in表達(dá)式,也可以使用dict函數(shù),代碼如下:print(dict(sorted(x.items(),key=lambdaitem:item[1])))如果不想使用lambda表達(dá)式,或需要更復(fù)雜的排序規(guī)則,可以自定義排序規(guī)則函數(shù),代碼如下:

      defdict_val(x):

      returnx[1]

      sorted_x=sorted(x.items(),key=dict_val)

      如果讀者用的是3.6或以下版本的Python,可以使用下面的代碼:

      importoperator

      #按value

      sorted_x=sorted(x.items(),key=operator.itemgetter(1))

      print(type(sorted_x))#list

      print(sorted_x)#所以用列表替代

      importoperator

      #按key

      sorted_x=sorted(x.items(),key=operator.itemgetter(0))

      print(sorted_x)

      在這段代碼中,會返回排好序的列表,列表元素是元組形式,第1個值是key,第2個值是value。當(dāng)然,你可以將這些數(shù)據(jù)重新插入新的字典中。執(zhí)行這段代碼,會輸出如下內(nèi)容:

      [('b',5),('a',12),('x',20)]

      [('a',12),('b',5),('x',20)]

      如果仍然想通過key搜索字典中的value,可以利用OrderedDict對象將sorted_x轉(zhuǎn)換為有序字典,代碼如下:

      importcollections

      sorted_dict=collections.OrderedDict(sorted_x)

      print(type(sorted_dict))

      print(sorted_dict)

      print(sorted_dict.get('b'))

      執(zhí)行這段代碼,會輸出如下內(nèi)容:

      OrderedDict([('a',12),('b',5),('x',20)])

      5

      總結(jié):本文的核心就是sorted函數(shù),通過這個函數(shù),既可以對key和value集合進(jìn)行排序,也可以對key-value對進(jìn)行排序,如果是后者,需要通過key指定到底是用key,還是用value排序,sorted函數(shù)返回的是排好序的列表,如果要得到排好序的字典,或者使用for-in表達(dá)式處理,或者使用dict函數(shù)轉(zhuǎn)換。當(dāng)然,如果只是想通過key搜索value,也可以將數(shù)據(jù)放到OrderedDict對象中。

      以上內(nèi)容為大家介紹了Python的字典排序,希望對大家有所幫助,如果想要了解更多Python相關(guān)知識,請關(guān)注IT培訓(xùn)機(jī)構(gòu):千鋒教育。http://www.jsszjs.cn/

      聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
      10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
      請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
      免費(fèi)領(lǐng)取
      今日已有369人領(lǐng)取成功
      劉同學(xué) 138****2860 剛剛成功領(lǐng)取
      王同學(xué) 131****2015 剛剛成功領(lǐng)取
      張同學(xué) 133****4652 剛剛成功領(lǐng)取
      李同學(xué) 135****8607 剛剛成功領(lǐng)取
      楊同學(xué) 132****5667 剛剛成功領(lǐng)取
      岳同學(xué) 134****6652 剛剛成功領(lǐng)取
      梁同學(xué) 157****2950 剛剛成功領(lǐng)取
      劉同學(xué) 189****1015 剛剛成功領(lǐng)取
      張同學(xué) 155****4678 剛剛成功領(lǐng)取
      鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
      董同學(xué) 138****2867 剛剛成功領(lǐng)取
      周同學(xué) 136****3602 剛剛成功領(lǐng)取
      相關(guān)推薦HOT
      如何理解Python一切都是變量的說法?

      Python的好處之一是與其他語法繁重的語言相比,Python具有相對易用的特點(diǎn)。但是,隨著深入的學(xué)習(xí)就會發(fā)現(xiàn)Python有許多隱藏的特性貫穿其中,因此...詳情>>

      2023-11-07 05:17:08
      Python內(nèi)置函數(shù)

      python中有許多內(nèi)置函數(shù),不像print那么廣為人知,但它們卻異常的強(qiáng)大,用好了可以大大提高代碼效率。這次來梳理下8個好用的python內(nèi)置函數(shù)。1...詳情>>

      2023-11-07 05:06:20
      用 Python 高效背單詞

      作為一個程序員,經(jīng)常需要閱讀英文論文、文檔、書籍。對于一些基礎(chǔ)不好的同學(xué)來說,最主要的攔路虎是英語單詞。計算機(jī)類文檔不同于小說,其語法...詳情>>

      2023-11-07 04:33:56
      Python處理文件的幾個常用小知識

      python這門語言有個很大的用途就是使用它來進(jìn)行文件處理,學(xué)會處理文件和保存數(shù)據(jù)可以讓你的程序使用起來更加容易和方便,因此小編為大家準(zhǔn)備了...詳情>>

      2023-11-07 03:54:20
      python經(jīng)典最短代碼實(shí)現(xiàn)排序的功能

      冒泡排序:算法思想:1.比較相鄰的元素,如果第一個比第二個大,則交換他們的位置;2.依次對每一對的元素進(jìn)行比較,如果前一個比后一個大,則交...詳情>>

      2023-11-07 03:50:44