[902]python list排序

时间:2022-07-26
本文章向大家介绍[902]python list排序,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

sorted函数

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

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

普通list

>>> a = [5,2,9,8,6]
>>> a = sorted(a)
>>> print(a)
[2, 5, 6, 8, 9]

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

>>> 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]。

按第一个关键字排序

>>> 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)]

按第二个关键字排序

>>> 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

>>> 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中元素倒序

>>> 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)

正向排序

>>>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]

反向排序

>>>L = [2,3,1,4]
>>>L.sort(reverse=True)
>>>L
>>>[4,3,2,1]

对第二个关键字排序

-----------------------------------------方法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)]

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

>>> 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