如何對(duì)python的字典進(jìn)行排序
我們知道Python的內(nèi)置dictionary數(shù)據(jù)類型是無(wú)序的,通過(guò)key來(lái)獲取對(duì)應(yīng)的value??墒怯袝r(shí)我們需要對(duì)dictionary中 的item進(jìn)行排序輸出,可能根據(jù)key,也可能根據(jù)value來(lái)排。到底有多少種方法可以實(shí)現(xiàn)對(duì)dictionary的內(nèi)容進(jìn)行排序輸出呢?下面摘取了 一些精彩的解決辦法。
python對(duì)容器內(nèi)數(shù)據(jù)的排序有兩種,一種是容器自己的sort函數(shù),一種是內(nèi)建的sorted函數(shù)。
sort函數(shù)和sorted函數(shù)唯一的不同是,sort是在容器內(nèi)(in-place)排序,sorted生成一個(gè)新的排好序的容器。
1 按照Key值排序
#最簡(jiǎn)單的方法,這個(gè)是按照key值排序: def sortedDictValues1(adict): items = adict.items() items.sort() return [value for key, value in items] #又一個(gè)按照key值排序,貌似比上一個(gè)速度要快點(diǎn) def sortedDictValues2(adict): keys = adict.keys() keys.sort() return [dict[key] for key in keys] #還是按key值排序,據(jù)說(shuō)更快。。。而且當(dāng)key為tuple的時(shí)候照樣適用 def sortedDictValues3(adict): keys = adict.keys() keys.sort() return map(adict.get, keys) #一行語(yǔ)句搞定: [(k,di[k]) for k in sorted(di.keys())] #用sorted函數(shù)的key參數(shù)(func)排序: #按照key進(jìn)行排序 print sorted(dict1.items(), key=lambda d: d[0])
2 按照value值排序
#來(lái)一個(gè)根據(jù)value排序的,先把item的key和value交換位置放入一個(gè)list中,再根據(jù)list每個(gè)元素的第一個(gè)值,即原來(lái)的value值, 排序: def sort_by_value(d): items=d.items() backitems=[[v[1],v[0]] for v in items] backitems.sort() return [ backitems[i][1] for i in range(0,len(backitems))] #還是一行搞定: [ v for v in sorted(di.values())] #用lambda表達(dá)式來(lái)排序,更靈活: sorted(d.items(), lambda x, y: cmp(x[1], y[1])), 或反序: sorted(d.items(), lambda x, y: cmp(x[1], y[1]), reverse=True) #用sorted函數(shù)的key參數(shù)(func)排序: # 按照value進(jìn)行排序 print sorted(dict1.items(), key=lambda d: d[1])
知識(shí)點(diǎn)擴(kuò)展:
準(zhǔn)備知識(shí):
在python里,字典dictionary是內(nèi)置的數(shù)據(jù)類型,是個(gè)無(wú)序的存儲(chǔ)結(jié)構(gòu),每一元素是key-value對(duì):
如:dict = {'username':'password','database':'master'},其中'username'和'database'是key,而'password'和'master'是value,可以通過(guò)d[key]獲得對(duì)應(yīng)值value的引用,但是不能通過(guò)value得到key。
對(duì)于dictionnary,需知道以下幾點(diǎn)注意事項(xiàng):
a、 dictionary 的 key 是大小寫敏感的;
b、 一個(gè)dictionary中不能有重復(fù)的 key;
c、 dictionary是無(wú)序的,沒(méi)有元素順序的概念,它們只是序偶的簡(jiǎn)單排列。
到此這篇關(guān)于如何對(duì)python的字典進(jìn)行排序的文章就介紹到這了,更多相關(guān)python的字典進(jìn)行排序方法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python??序列化反序列化和異常處理的問(wèn)題小結(jié)
這篇文章主要介紹了Python?序列化反序列化和異常處理,本文結(jié)合示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-12-12Python爬蟲urllib和requests的區(qū)別詳解
這篇文章主要介紹了Python爬蟲urllib和requests的區(qū)別詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-09-09Python操作MySQL數(shù)據(jù)庫(kù)的示例代碼
這篇文章主要介紹了Python操作MySQL數(shù)據(jù)庫(kù)的方法,文中示例代碼非常詳細(xì),幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下2020-07-07python基于Pandas讀寫MySQL數(shù)據(jù)庫(kù)
這篇文章主要介紹了python基于Pandas讀寫MySQL數(shù)據(jù)庫(kù),幫助大家更好的理解和學(xué)習(xí)使用python,感興趣的朋友可以了解下2021-04-04分享2個(gè)方便調(diào)試Python代碼的實(shí)用工具
這篇文章主要介紹了分享方便調(diào)試Python代碼的2個(gè)實(shí)用工具,可以方便展示我們調(diào)試代碼的中間狀態(tài),提升大家的編碼效率,詳細(xì)的介紹需要的小伙伴可以參考一下下面文章內(nèi)容2022-05-05詳解django實(shí)現(xiàn)自定義manage命令的擴(kuò)展
這篇文章主要介紹了django實(shí)現(xiàn)自定義manage命令的擴(kuò)展,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08利用Anaconda完美解決Python 2與python 3的共存問(wèn)題
Anaconda 是 Python 的一個(gè)發(fā)行版,如果把 Python 比作 Linux,那么 Anancoda 就是 CentOS 或者 Ubuntu,下面這篇文章主要給大家介紹了利用Anaconda完美解決Python 2與python 3共存問(wèn)題的相關(guān)資料,文中介紹的非常詳細(xì),需要的朋友可以參考借鑒。2017-05-05