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