Python使用sorted對字典的key或value排序
sorted函數(shù)
sorted(iterable,key,reverse)
- iterable 待排序的可迭代對象
- key 對應(yīng)的是個(gè)函數(shù), 該函數(shù)用來決定選取用哪些值來進(jìn)行排序
- reverse 反轉(zhuǎn)排序
對key排序
d: dict = {"p": 59, "o": 9, "s": 5, "a": 20, "z": 18}
li: list = sorted(d.keys())
print(li)
執(zhí)行結(jié)果:
['a', 'o', 'p', 's', 'z']
對value排序
在對value之前, 先來回爐一下Python的lambda表達(dá)式
f = lambda x: x+1 print(f(5)) def ff(x): return x+1 print(ff(5))
執(zhí)行結(jié)果:
6
6
以上兩種方式是等價(jià)的, lambda表達(dá)式寫法更簡潔, 一般當(dāng)做匿名表達(dá)式/匿名函數(shù)使用
lambda x:y
- x 為入?yún)?/li>
- y 為計(jì)算表達(dá)式, 運(yùn)算后返回
接下來進(jìn)入到對字典的value排序正題, 這里就需要使用到lambda表達(dá)式
直接對值排序
d: dict = {"p": 59, "o": 9, "s": 5, "a": 20, "z": 18}
li: list = sorted(d.values())
print(li)
執(zhí)行結(jié)果:
[5, 9, 18, 20, 59]
在包含Key的情況下對值排序
d: dict = {"p": 59, "o": 9, "s": 5, "a": 20, "z": 18}
li: list = sorted(d.items(), key=lambda x: x[1])
print(li)
執(zhí)行結(jié)果:
[('s', 5), ('o', 9), ('z', 18), ('a', 20), ('p', 59)]
d.items() 返回以元組形式構(gòu)成的列表 dict_items([('p', 59), ('o', 9), ('s', 5), ('a', 20), ('z', 18)]) (列表為可迭代對象)
lambda x: x[1] lambda表達(dá)式中, x為入?yún)? 每次x的值為一個(gè)d.items()中的元素(一個(gè)元組), 第一個(gè)入?yún)?'p', 59) 冒號后面的x[1]是運(yùn)算表達(dá)式, 意思是取元組中的第二個(gè)元素返回(索引為1), 返回的元素即為排序的依據(jù). 所以如果需要對key進(jìn)行排序, 也可以在表達(dá)式里寫 x[0]
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python?作為小程序后端的三種實(shí)現(xiàn)方法(推薦)
這篇文章主要介紹了Python?作為小程序后端的三種方法,在這比較推薦前兩種方法,本文通過實(shí)例圖文相結(jié)合給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-05-05
OpenCV中resize函數(shù)插值算法的實(shí)現(xiàn)過程(五種)
最新版OpenCV2.4.7中,cv::resize函數(shù)有五種插值算法:最近鄰、雙線性、雙三次、基于像素區(qū)域關(guān)系、蘭索斯插值。感興趣的可以了解一下2021-06-06
分享python數(shù)據(jù)統(tǒng)計(jì)的一些小技巧
今天這些小技巧在處理python的一些數(shù)據(jù)方面還是很有幫助的,希望能幫到在這方面有需要的童鞋~2016-07-07
PO模式在selenium自動(dòng)化測試框架的優(yōu)勢
大家都知道po模式可以提高代碼的可讀性和減少了代碼的重復(fù),但是相對的缺點(diǎn)還有,今天通過本文一起學(xué)習(xí)下PO模式在selenium自動(dòng)化測試框架的優(yōu)勢,需要的朋友可以參考下2022-03-03
Pycharm中出現(xiàn)ImportError:DLL load failed:找不到指定模塊的解決方法
這篇文章主要介紹了Pycharm中出現(xiàn)ImportError:DLL load failed:找不到指定模塊的解決方法,需要的朋友可以參考下2019-09-09
windowns使用PySpark環(huán)境配置和基本操作
pyspark是Spark對Python的api接口,可以在Python環(huán)境中通過調(diào)用pyspark模塊來操作spark,這篇文章主要介紹了windowns使用PySpark環(huán)境配置和基本操作,感興趣的可以了解一下2021-05-05

