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