摘要:我們知道的內(nèi)置數(shù)據(jù)類型是無序的,通過來獲取對應(yīng)的??墒怯袝r我們需要對中的進(jìn)行排序輸出,可能根據(jù),也可能根據(jù)來排。最簡單的方法,這個是按照值排序又一個按照值排序,貌似比上一個速度要快點(diǎn)還是按值排序,據(jù)說更快。。。
我們知道Python的內(nèi)置dictionary數(shù)據(jù)類型是無序的,通過key來獲取對應(yīng)的value。可是有時我們需要對dictionary中 的item進(jìn)行排序輸出,可能根據(jù)key,也可能根據(jù)value來排。到底有多少種方法可以實(shí)現(xiàn)對dictionary的內(nèi)容進(jìn)行排序輸出呢?下面摘取了 一些精彩的解決辦法。
最簡單的方法,這個是按照key值排序:def sortedDictValues1(adict): items = adict.items() items.sort() return [value for key, value in items]又一個按照key值排序,貌似比上一個速度要快點(diǎn)
def sortedDictValues2(adict): keys = adict.keys() keys.sort() return [dict[key] for key in keys]還是按key值排序,據(jù)說更快。。。而且當(dāng)key為tuple的時候照樣適用
def sortedDictValues3(adict): keys = adict.keys() keys.sort() return map(adict.get, keys)一行語句搞定:
[(k,di[k]) for k in sorted(di.keys())]來一個根據(jù)value排序的,先把item的key和value交換位置放入一個list中,再根據(jù)list每個元素的第一個值,即原來的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á)式來排序,更靈活:
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ù)排序: 按照key進(jìn)行排序
print sorted(dict1.items(), key=lambda d: d[0])按照value進(jìn)行排序
print sorted(dict1.items(), key=lambda d: d[1])
下面給出python內(nèi)置sorted函數(shù)的幫助文檔:
sorted(...)
sorted(iterable, cmp=None, key=None, reverse=False) --> new sorted list
看了上面這么多種對dictionary排序的方法,其實(shí)它們的核心思想都一樣,即把dictionary中的元素分離出來放到一個list中,對list排序,從而間接實(shí)現(xiàn)對dictionary的排序。這個“元素”可以是key,value或者item。
一上轉(zhuǎn)
按照value排序可以用
sorted(d.items, key=lambda d:d[1])
若版本低不支持sorted
將key,value 以tuple一起放在一個list中
l = []
l.append((akey,avalue))...
用sort()
l.sort(lambda a,b :cmp(a[1],b[1]))(cmp前加“-”表示降序排序)
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/45433.html
摘要:新年快樂大家好,今天是大年初二,身在國外沒有過年的氛圍,只能踏實(shí)寫寫文章,對社區(qū)做點(diǎn)貢獻(xiàn),在此祝大家新年快樂上一期為大家梳理了一些的進(jìn)階用法,今天我們來看字典的相關(guān)技巧,我個人在編程中對字典的使用非常頻繁,其實(shí)對于不是非常大的數(shù)據(jù)存儲需求, 新年快樂 大家好,今天是大年初二,身在國外沒有過年的氛圍,只能踏實(shí)寫寫文章,對社區(qū)做點(diǎn)貢獻(xiàn),在此祝大家新年快樂!上一期為大家梳理了一些List的進(jìn)...
摘要:,同為小白的朋友們大家好,這期主要為大家?guī)碛嘘P(guān)字典的一些實(shí)用技巧。上篇筆記通過感人肺腑的老白讓大家認(rèn)識到了字典這么有用的數(shù)據(jù)類型,這一期讓我們看看如何能更好的操作字典。 Hello ,同為小白的朋友們大家好,這期主要為大家?guī)碛嘘P(guān)字典的一些實(shí)用技巧。上篇筆記通過感人肺腑的老白讓大家認(rèn)識到了字典這么有用的數(shù)據(jù)類型,這一期讓我們看看如何能更好的操作字典。 基礎(chǔ)篇 下面我給大家來一個簡單的...
摘要:一需要用到的函數(shù)需要用到的函數(shù)很少,基本上就是和。這個參數(shù)的默認(rèn)值是恒等函數(shù),也就是默認(rèn)用元素自己的值來排序。后的函數(shù)會代入列表里的每一項(xiàng)返回一個優(yōu)先級數(shù)字,并以這個優(yōu)先級數(shù)字排序 一、需要用到的函數(shù) 需要用到的函數(shù)很少,基本上就是sorted()和lambda。 sorted()函數(shù)原型: sorted(iterable[,key][,reverse]) 可見sorted()可以接...
摘要:因其在各個領(lǐng)域的實(shí)用性與和等其他編程語言相比的生產(chǎn)力以及與英語類似的命令而廣受歡迎。反轉(zhuǎn)字典一個非常常見的字典任務(wù)是如果我們有一個字典并且想要反轉(zhuǎn)它的鍵和值。 ??...
摘要:整理了一些個人在利用處理文件時經(jīng)常用到的一些自定義方法,放在這里主要方便自己查閱,也可以給其他人做參考目錄輸出文件某列的匹配不匹配的記錄調(diào)整文件的列的順序轉(zhuǎn)換器抽取特定列除去完全重復(fù)的記錄根據(jù)列名排序鍵值互換輸出文件某列的匹配不匹配的記錄主 Python CSV Toolkit 整理了一些個人在利用python處理csv文件時經(jīng)常用到的一些自定義方法,放在這里主要方便自己查閱,也可以給...
閱讀 3491·2023-04-25 22:45
閱讀 1294·2021-11-11 16:54
閱讀 2802·2019-08-30 15:44
閱讀 3198·2019-08-30 15:44
閱讀 1654·2019-08-30 13:55
閱讀 948·2019-08-29 18:45
閱讀 1207·2019-08-29 17:25
閱讀 1017·2019-08-29 12:59