前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >[902]python list排序

[902]python list排序

作者头像
周小董
发布2020-09-30 10:45:12
6810
发布2020-09-30 10:45:12
举报
文章被收录于专栏:python前行者python前行者

sorted函数

使用python的sorted函数,该函数默认从小到大排序

sorted(list)返回一个对象,可以用作表达式。原来的list不变,生成一个新的排好序的list对象。

普通list
代码语言:javascript
复制
>>> a = [5,2,9,8,6]
>>> a = sorted(a)
>>> print(a)
[2, 5, 6, 8, 9]

倒序排序为从大到小排序,使用reverse=True

代码语言:javascript
复制
>>> a = [5,2,9,8,6]
>>> a = sorted(a,reverse=True)
>>> print(a)
[9, 8, 6, 5, 2]
元组list

列表元素为元组元素时,我们需要用到参数关键词key,lambda是一个隐函数,是固定写法,x表示列表中的一个元素,在这里,表示一个元组,x为任意名;x[0]表示元组里的第一个元素,第二个元素就是x[1]。

按第一个关键字排序

代码语言:javascript
复制
>>> a = [('x',0.56),('a',1.28),('c',2.36),('s',5.02),('h',20)]
>>> a = sorted(a,key = lambda x:x[0])
>>> print(a)
[('a', 1.28), ('c', 2.36), ('h', 20), ('s', 5.02), ('x', 0.56)]

按第二个关键字排序

代码语言:javascript
复制
>>> a = [('x',0.56),('a',1.28),('c',2.36),('s',5.02),('h',20)]
>>> a = sorted(a,key = lambda x:x[1])
>>> print(a)
[('x', 0.56), ('a', 1.28), ('c', 2.36), ('s', 5.02), ('h', 20)]

倒序排序为从大到小排序,使用reverse=True

代码语言:javascript
复制
>>> a = [('x',0.56),('a',1.28),('c',2.36),('s',5.02),('h',20)]
>>> a = sorted(a,key = lambda x:x[1],reverse=True)
>>> print(a)
[('h', 20), ('s', 5.02), ('c', 2.36), ('a', 1.28), ('x', 0.56)]

对列表中元素倒序

使用reverse函数,是对list中元素倒序

代码语言:javascript
复制
>>> a = [('x',0.56),('a',1.28),('c',2.36),('s',5.02),('h',20)]
>>> a.reverse()
>>> print(a)
[('h', 20), ('s', 5.02), ('c', 2.36), ('a', 1.28), ('x', 0.56)]

list.sort()

list.sort() 不会返回对象,改变原有的list。

list.sort(func=None, key=None, reverse=False)

正向排序

代码语言:javascript
复制
>>>L = [2,3,1,4]
>>>L.sort()
>>>L
>>>[1,2,3,4]

>>> L = [2,3,1,4]
>>> a=L.sort()
>>> a #这里a为None 
>>> L
[1, 2, 3, 4]

反向排序

代码语言:javascript
复制
>>>L = [2,3,1,4]
>>>L.sort(reverse=True)
>>>L
>>>[4,3,2,1]

对第二个关键字排序

代码语言:javascript
复制
-----------------------------------------方法1------------------------------------
>>>L = [('b',6),('a',1),('c',3),('d',4)]
>>>L.sort(lambda x,y:cmp(x[1],y[1])) 
>>>L
>>>[('a', 1), ('c', 3), ('d', 4), ('b', 6)]

-----------------------------------------方法2------------------------------------
>>>L = [('b',6),('a',1),('c',3),('d',4)]
>>>L.sort(key=lambda x:x[1]) 
>>>L
>>>[('a', 1), ('c', 3), ('d', 4), ('b', 6)]

-----------------------------------------方法3------------------------------------
>>>L = [('b',2),('a',1),('c',3),('d',4)]
>>>import operator
>>>L.sort(key=operator.itemgetter(1)) 
>>>L
>>>[('a', 1), ('b', 2), ('c', 3), ('d', 4)]

------------------------------------(DSU方法:Decorate-Sort-Undercorate)-------------------------------------
>>>L = [('b',2),('a',1),('c',3),('d',4)]
>>>A = [(x[1],i,x) for i,x in enumerate(L)] #i can confirm the stable sort
>>>A.sort()
>>>L = [s[2] for s in A]
>>>L
>>>[('a', 1), ('b', 2), ('c', 3), ('d', 4)]

如果我们想用第二个关键字排过序后再用第一个关键字进行排序呢?有两种方法

代码语言:javascript
复制
>>> L = [('d',2),('a',4),('b',3),('c',2)]
>>> L.sort(key=lambda x:(x[1],x[0]))
>>> L
>>>[('c', 2), ('d', 2), ('b', 3), ('a', 4)]

-----------------------------------------------------------------------
>>> L = [('d',2),('a',4),('b',3),('c',2)]
>>> L.sort(key=operator.itemgetter(1,0))
>>> L
>>>[('c', 2), ('d', 2), ('b', 3), ('a', 4)]

参考:https://www.cnblogs.com/qilin20/p/12301878.html https://www.cnblogs.com/python960410445/p/11831393.html

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-09-29 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • sorted函数
    • 普通list
      • 元组list
      • 对列表中元素倒序
      • list.sort()
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档