亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

Python sorted對list和dict排序

瀏覽:2日期:2022-07-22 08:04:48

sorted語法

sorted(iterable, key=None, reverse=False)

參數說明:

- iterable -- 可迭代對象。 - key --主要是用來進行比較的元素,只有一個參數,具體的函數的參數就是取自于可迭代對象中,指定可迭代對象中的一個元素來進行排序。 - reverse -- 排序規則,reverse = True 降序 , reverse = False 升序(默認)。

返回: - 一個新list對象

sorted對字典dict排序

①按鍵key排序

from operator import itemgetterdict = {3: ’B’, 1: ’A’, 2: ’C’}# 按key升序 .items()取得3個(key,value)# lambda x: x[0]取(key,value)的key 即(3,1,2)d1 = sorted(dict.items(), key=lambda x: x[0], reverse=False) # <class ’list’># 按key降序 itemgetter類似lambdad2 = sorted(dict.items(), key=itemgetter(0), reverse=True) # <class ’list’># 輸出print(d1, type(d1)) # [(1, ’A’), (2, ’C’), (3, ’B’)] <class ’list’>print(d2, type(d2)) # [(3, ’B’), (2, ’C’), (1, ’A’)] <class ’list’>

[(1, ‘A’), (2, ‘C’), (3, ‘B’)] <class ‘list’>[(3, ‘B’), (2, ‘C’), (1, ‘A’)] <class ‘list’>

②按值value排序

from operator import itemgetterdict = {3: ’B’, 1: ’A’, 2: ’C’}# 按value升序 .items()取得3個(key,value)# lambda x: x[1]取(key,value)的value 即(’B’,’A’,’C’)d3 = sorted(dict.items(), key=lambda x: x[1], reverse=False) # <class ’list’># 按value降序 itemgetter類似lambdad4 = sorted(dict.items(), key=itemgetter(1), reverse=True) # <class ’list’>print(d3, type(d3)) # [(1, ’A’), (3, ’B’), (2, ’C’)] <class ’list’>print(d4, type(d4)) # [(2, ’C’), (3, ’B’), (1, ’A’)] <class ’list’>

[(1, ‘A’), (3, ‘B’), (2, ‘C’)] <class ‘list’>[(2, ‘C’), (3, ‘B’), (1, ‘A’)] <class ‘list’>

sorted排序list

①按一種規則排序list

from operator import itemgetterdata = [(’c’, 3, ’Apple’), (’d’, 1, ’Cat’), (’a’, 2, ’Banana’)]# 根據字母升序print(sorted(data, key=lambda x: x[0], reverse=False)) # <class ’list’># 根據數字升序print(sorted(data, key=lambda x: x[1], reverse=False)) # <class ’list’># 根據單詞升序print(sorted(data, key=lambda x: x[2], reverse=False)) # <class ’list’>

[(’a’, 2, ’Banana’), (’c’, 3, ’Apple’), (’d’, 1, ’Cat’)][(’d’, 1, ’Cat’), (’a’, 2, ’Banana’), (’c’, 3, ’Apple’)][(’c’, 3, ’Apple’), (’a’, 2, ’Banana’), (’d’, 1, ’Cat’)]

②按多種規則排序list

# 先按照成績降序排序,相同成績的按照名字升序排序:d1 = [{’name’:’alice’, ’score’:38}, {’name’:’bob’, ’score’:18}, {’name’:’darl’, ’score’:28}, {’name’:’christ’, ’score’:28}]l = sorted(d1, key=lambda x:(-x[’score’], x[’name’]))print(l)

[{’name’: ’alice’, ’score’: 38}, {’name’: ’christ’, ’score’: 28}, {’name’: ’darl’, ’score’: 28}, {’name’: ’bob’, ’score’: 18}]

sorted排序list和dict的混合

先看看我們排序的有哪些類型的數據結構

#### 二維list排序l1 = [[’Bob’, 95.00, ’A’], [’Alan’, 86.0, ’C’], [’Mandy’, 82.5, ’A’], [’Rob’, 86, ’E’]]#### list中混合字典l2 = [{’name’:’alice’, ’score’:38}, {’name’:’bob’, ’score’:18}, {’name’:’darl’, ’score’:28}, {’name’:’christ’, ’score’:28}]#### 字典中混合listd1 = {’Li’: [’M’, 7], ’Zhang’: [’E’, 2], ’Wang’: [’P’, 3], ’Du’: [’C’, 2], ’Ma’: [’C’, 9], ’Zhe’: [’H’, 7]}#### 對字典中的多維list進行排序d2 = { ’Apple’: [[’44’, 88], [’11’, 33], [’22’, 88]], ’Banana’: [[’55’, 43], [’11’, 68], [’44’, 22]], ’Orange’:[[’22’, 22], [’55’, 41], [’44’, 42], [’33’, 22]]}

二維list排序

from operator import itemgetterl1 = [[’Bob’, 95.00, ’A’], [’Alan’, 86.0, ’C’], [’Mandy’, 82.5, ’A’], [’Rob’, 86, ’E’]]# 按先按成績號升序,再按成績數值升序print(sorted(l1, key=itemgetter(2, 1), reverse=False))# 按先按成績號升序,再按成績數值降序序print(sorted(l1, key=lambda x:(x[2], -x[1]), reverse=False))

[[‘Mandy’, 82.5, ‘A’], [‘Bob’, 95.0, ‘A’], [‘Alan’, 86.0, ‘C’], [‘Rob’, 86, ‘E’]][[‘Bob’, 95.0, ‘A’], [‘Mandy’, 82.5, ‘A’], [‘Alan’, 86.0, ‘C’], [‘Rob’, 86, ‘E’]]

2. list中混合字典

from operator import itemgetter# 先按照成績降序排序,相同成績的按照名字升序排序:l2 = [{’name’:’alice’, ’score’:38}, {’name’:’bob’, ’score’:18}, {’name’:’darl’, ’score’:28}, {’name’:’christ’, ’score’:28}]print(sorted(l2, key=lambda x:(-x[’score’], x[’name’])))print(sorted(l2, key=itemgetter(’score’, ’name’)))

[{‘name’: ‘alice’, ‘score’: 38}, {‘name’: ‘christ’, ‘score’: 28}, {‘name’: ‘darl’, ‘score’: 28}, {‘name’: ‘bob’, ‘score’: 18}][{‘name’: ‘bob’, ‘score’: 18}, {‘name’: ‘christ’, ‘score’: 28}, {‘name’: ‘darl’, ‘score’: 28}, {‘name’: ‘alice’, ‘score’: 38}]

3. 字典中混合list

d1 = {’Li’: [’M’, 7], ’Zhang’: [’E’, 2], ’Wang’: [’P’, 3], ’Du’: [’C’, 2], ’Ma’: [’C’, 9], ’Zhe’: [’H’, 7]}# sort返回的是list,如果需要轉為dict,再sorted前面套一個dict()就可以了print(sorted(d1.items(), key=lambda x:(x[1][1], -ord(x[1][0]) ))) # 對字符比較需要ord。如果是’123’字符串數字可以使用int。# print(sorted(d1.items(), key=lambda x:(x[1][1], -ord(x[1][0]) )))

[(‘Zhang’, [‘E’, 2]), (‘Du’, [‘C’, 2]), (‘Wang’, [‘P’, 3]), (‘Li’, [‘M’, 7]), (‘Zhe’, [‘H’, 7]), (‘Ma’, [‘C’, 9])]

4. 對字典中的多維list進行排序

d2 = { ’Apple’: [[’44’, 88], [’11’, 33], [’22’, 88]], ’Banana’: [[’55’, 43], [’11’, 68], [’44’, 22]], ’Orange’:[[’22’, 22], [’55’, 41], [’44’, 42], [’33’, 22]]}for key, value in d2.items(): d2[key] = sorted(value, key=lambda x:(x[1], -int(x[0]))) # 按list第二列升序,相同則按第一列降序,參考二維list排序print(d2)

{‘Apple’: [[‘11’, 33], [‘44’, 88], [‘22’, 88]], ‘Banana’: [[‘44’, 22], [‘55’, 43], [‘11’, 68]], ‘Orange’: [[‘33’, 22], [‘22’, 22], [‘52’, 41], [‘44’, 42]]}

到此這篇關于Python sorted對list和dict排序的文章就介紹到這了,更多相關Python sorted對list和dict排序內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 久久综合草 | 香蕉视频在线网站 | 黄色网久久 | heyzo北条麻妃中文字幕 | 亚洲综合婷婷 | 91蜜桃传媒一二三区 | 国产成人一区二区三区精品久久 | 青青草综合视频 | 国内一级特黄女人精品片 | 久久一区不卡中文字幕 | 国语自产拍在线观看7m | 91精品麻豆 | 91先生在线 | 一级爱做片免费观看久久 | 另类图片第一页 | 国产三级不卡 | 欧美特级毛片 | 国内三级视频 | 麻豆国产果冻传媒网站入口 | 大学生一级特黄的免费大片视频 | 大色香蕉色视频大全 | 妞干网在线视频 | 久久爰www免费人成 久久狠狠干 | 麻豆黄色| 午夜影院一区二区三区 | 中文字幕日韩在线 | 亚洲一区www| 在线xxxx | 国产欧美在线一区二区三区 | 久久国产精品女 | 国产一区免费观看 | 大看蕉a在线观看 | 国产一级爱c片免费播放 | 黄色影片免费观看 | 我要看黄色特级黄色录像 | 国产精品久久福利新婚之夜 | 日韩欧美中文字幕在线视频 | 蜜桃臀在线成人亚洲 | 暧暧视频在线观看免费 | 国产麻豆视频网站 | 永久免费观看黄网站 |