python sorted排序:使用lambda應對各種復雜情況的排序,包括list嵌套dict

原文鏈接
https://www.polarxiong.com/archives/Python-%E4%BD%BF%E7%94%A8lambda%E5%BA%94%E5%AF%B9%E5%90%84%E7%A7%8D%E5%A4%8D%E6%9D%82%E6%83%85%E5%86%B5%E7%9A%84%E6%8E%92%E5%BA%8F-%E5%8C%85%E6%8B%AClist%E5%B5%8C%E5%A5%97dict.html
一、需要用到的函數(shù)
需要用到的函數(shù)很少,基本上就是sorted()和lambda。

sorted()
sorted()函數(shù)原型:

Python
sorted(iterable[,key][,reverse])
可見sorted()可以接受3個參數(shù),需要排序的變量必不可少,然后是key指定排序的元素,reverse指定是否逆序。

lambda
lambda實際上就是匿名函數(shù)

一般形式:

Python
lambda arguments: expression
寫成函數(shù)形式就是

Python
def <lambda>(arguments):
return expression
當lambda和sorted()的key參數(shù)結(jié)合就有意想不到的效果了。

二、各種排序
1.簡單list排序
Python
lis = ['a', 'b', 'c']
print(sorted(lis))

['a', 'b', 'c']

print(sorted(lis, reverse=True))

['c', 'b', 'a']

2.dict的key排序
Python
dic = {'c': 1, 'b': 2, 'a': 3}
print(sorted(dic))

['a', 'b', 'c']

print(sorted(dic, reverse=True))

['c', 'b', 'a']

3.dict的value排序
Python
dic = {'c': 1, 'b': 2, 'a': 3}
print(sorted(dic, key=lambda k: dic[k]))

['c', 'b', 'a']

print(sorted(dic, key=lambda k: dic[k], reverse=True))

['a', 'b', 'c']

4.list內(nèi)嵌套list排序
Python
lis = [[4, 2, 9], [1, 5, 6], [7, 8, 3]]
print(sorted(lis, key=lambda k: k[0]))

[[1, 5, 6], [4, 2, 9], [7, 8, 3]]

print(sorted(lis, key=lambda k: k[1]))

[[4, 2, 9], [1, 5, 6], [7, 8, 3]]

print(sorted(lis, key=lambda k: k[2]))

[[7, 8, 3], [1, 5, 6], [4, 2, 9]]

print(sorted(lis, key=lambda k: k[0], reverse=True))

[[7, 8, 3], [4, 2, 9], [1, 5, 6]]

5.dict內(nèi)嵌套dict排序
Python
dic = {
'a': {'x': 3, 'y': 2, 'z': 1},
'b': {'x': 2, 'y': 1, 'z': 3},
'c': {'x': 1, 'y': 3, 'z': 2},
}
print(sorted(dic, key=lambda k: dic[k]['x']))

['c', 'b', 'a']

print(sorted(dic, key=lambda k: dic[k]['y']))

['b', 'a', 'c']

print(sorted(dic, key=lambda k: dic[k]['z']))

['a', 'c', 'b']

print(sorted(dic, key=lambda k: dic[k]['x'], reverse=True))

['a', 'b', 'c']

6.list內(nèi)嵌套dict排序
Python
lis = [
{'x': 3, 'y': 2, 'z': 1},
{'x': 2, 'y': 1, 'z': 3},
{'x': 1, 'y': 3, 'z': 2},
]
print(sorted(lis, key=lambda k: k['x']))

[{'z': 2, 'x': 1, 'y': 3}, {'z': 3, 'x': 2, 'y': 1}, {'z': 1, 'x': 3, 'y': 2}]

print(sorted(lis, key=lambda k: k['y']))

[{'z': 3, 'x': 2, 'y': 1}, {'z': 1, 'x': 3, 'y': 2}, {'z': 2, 'x': 1, 'y': 3}]

print(sorted(lis, key=lambda k: k['z']))

[{'z': 1, 'x': 3, 'y': 2}, {'z': 2, 'x': 1, 'y': 3}, {'z': 3, 'x': 2, 'y': 1}]

print(sorted(lis, key=lambda k: k['x'], reverse=True))

[{'z': 1, 'x': 3, 'y': 2}, {'z': 3, 'x': 2, 'y': 1}, {'z': 2, 'x': 1, 'y': 3}]

7.dict內(nèi)嵌套list排序
Python
dic = {
'a': [1, 2, 3],
'b': [2, 1, 3],
'c': [3, 1, 2],
}
print(sorted(dic, key=lambda k: dic[k][0]))

['a', 'b', 'c']

print(sorted(dic, key=lambda k: dic[k][1]))

['b', 'c', 'a']

print(sorted(dic, key=lambda k: dic[k][2]))

['c', 'b', 'a']

print(sorted(dic, key=lambda k: dic[k][0], reverse=True))

['c', 'b', 'a']

三、其他更深層嵌套排序
更深層嵌套排序方法和上面介紹的大同小異,實際就是lambda的操作;需要注意的就是dict的排序只會取其key,所以需要lambda首先將其轉(zhuǎn)換為value才能操作value排序。

?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

  • 用于python面試整理,主要來源于http://www.cnblogs.com/skiler/p/6952707...
    AIM外星人閱讀 2,470評論 0 13
  • 一、快捷鍵 ctr+b 執(zhí)行ctr+/ 單行注釋ctr+c ...
    o_8319閱讀 6,031評論 2 16
  • 你在雨中等著我 但你應該清楚 你已經(jīng)錯過了我的那趟火車 你是否聽到火車的鳴笛聲 那就是我們之間的離歌 那年夏夜,滿...
    佳佳佳油123閱讀 514評論 0 2
  • 分享嘉賓:任博 學委:王丹丹F62,陳廷偉F69 使用“翻轉(zhuǎn)課堂”學習DISC注意事項: 1、學習是自己的事,本方...
    像夏花般絢爛閱讀 533評論 0 1
  • 親子日記第五篇。11月16日,今天早上女兒自己起床,起來時發(fā)現(xiàn)弟弟醒了,我在做早餐,她就陪著她弟弟在床上玩,擔心弟...
    4eec5d2d7bf8閱讀 184評論 0 1

友情鏈接更多精彩內(nèi)容