Python教程按照字典的鍵或值進(jìn)行排序方法解析
Python sorted() 函數(shù)
sorted() 函數(shù)對(duì)所有可迭代的對(duì)象進(jìn)行排序操作
sorted 語法:
sorted(iterable, key=None, reverse=False)
參數(shù)說明:
iterable – 可迭代對(duì)象。
key – 主要是用來進(jìn)行比較的元素,只有一個(gè)參數(shù),具體的函數(shù)的參數(shù)就是取自于可迭代對(duì)象中,指定可迭代對(duì)象中的一個(gè)元素來進(jìn)行排序。
reverse – 排序規(guī)則,reverse = True 降序 , reverse = False 升序(默認(rèn))。
1、對(duì)字典按鍵(key)進(jìn)行排序
dir_info= {'a':1,'d':8,'c':3,'b':5}
#對(duì)字典按鍵(key)進(jìn)行排序(默認(rèn)由小到大)
dir_sort = sorted(dir_info.items(),key=lambda x:x[0])
print(dir_sort)
輸出結(jié)果:
[('a', 1), ('b', 5), ('c', 3), ('d', 8)]
直接對(duì)字典的key排序
sorted({'a':1,'d':8,'c':3,'b':5}.keys())
2、對(duì)字典按值(value)進(jìn)行排序
dir_info= {'a':1,'d':8,'c':3,'b':5}
#對(duì)字典按鍵(key)進(jìn)行排序(默認(rèn)由小到大)
dir_sort = sorted(dir_info.items(),key=lambda x:x[1])
print(dir_sort)
輸出結(jié)果
[('a', 1), ('c', 3), ('b', 5), ('d', 8)]
直接對(duì)字典的value排序
sorted({'a':1,'d':8,'c':3,'b':5}.values())
解析:
dir_info.items()是獲得了字典的key,value 兩個(gè)參數(shù)
dir_info[0]表示按照第一元素進(jìn)行排序
dir_info[1]表示按照第二個(gè)元素進(jìn)行排序
為了便于理解,再舉個(gè)例子
person_info = [('zhangsan', '男', 15), ('lisi', '男', 12), ('wangwu', '男', 10),]
person_sort = sorted(person_info, key=lambda x: x[2])
print(person_sort)
輸出結(jié)果:
[('wangwu', '男', 10), ('lisi', '男', 12), ('zhangsan', '男', 15)]
當(dāng)然key的形式也是多樣的
比如:
1.按照字符串長度進(jìn)行排序
key = lambda x:len(x)
2.先按照第一個(gè)元素,再按照第二個(gè)元素:
key = lambda x : (x[0] , x[1])
擴(kuò)展:
將列表中數(shù)據(jù)的某一部分作為關(guān)鍵字進(jìn)行排序(選取標(biāo)志性可用于排序的元素作為條件)
list_info = ['test-10.txt','test-11.txt','test-22.txt','test-14.txt','test-3.txt','test-20.txt']
list_sort = sorted(list_info, key=lambda d : int(d.split('-')[1].split('.')[0]))
print(list_sort)
輸出結(jié)果
['test-3.txt', 'test-10.txt', 'test-11.txt', 'test-14.txt', 'test-20.txt', 'test-22.txt']
以上就是Python教程按照字典的鍵或值進(jìn)行排序方法解析的詳細(xì)內(nèi)容,更多關(guān)于Python按照字典的鍵或值進(jìn)行排序的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Django ValuesQuerySet轉(zhuǎn)json方式
這篇文章主要介紹了Django ValuesQuerySet轉(zhuǎn)json方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-03-03
python查詢MySQL將數(shù)據(jù)寫入Excel
這篇文章主要介紹了python如何查詢MySQL將數(shù)據(jù)寫入Excel,幫助大家利用python高效的辦公,感興趣的朋友可以了解下2020-10-10

