python--sort()和sorted()高级排序

1、list中的sort()方法: 

def sort(self, key=None, reverse=False): # real signature unknown; restored from __doc__
        """ L.sort(key=None, reverse=False) -> None -- stable sort *IN PLACE* """
        pass
'''
key:是排序的条件,可以是:key=int,key=len, key=lambda..
reverse:表示是否反序,默认从小到大,默认为Flase

'''
##一个list调用sort方法后,对原list进行排序

## 1、最简单的排序
l = [5,2,3,1,4 ]
l .sort()
print(l)   ##输出:[1, 2, 3, 4, 5]

l.sort(reverse=True)#反序
print(l)    ##输出:[5, 4, 3, 2, 1]

##2、字符串排序
StrList = ['fb', 'bx', 'csw', 'qb', 'qqa', 'eeeed']
2.1 一般字典序排列,但是大写在前,小写在后!!
StrList.sort()
print(StrList) ##字符串列表是按照第一个字符的大小排序的
##输出:['Fast', 'Smooth', 'fast', 'is', 'is', 'smooth']

2.2忽略大小写,按abcd顺序
StrList.sort(key=str.lower)
print(StrList) ##输出:['Fast', 'fast', 'is', 'is', 'Smooth', 'smooth']

2.3按照字符串长度排序
StrList.sort(key=len)
print(StrList)##输出:['is', 'is', 'fast', 'Fast', 'Smooth', 'smooth']

StrList.sort(key=len, reverse=True)#反序
print(StrList) ##输出:['Smooth', 'smooth', 'fast', 'Fast', 'is', 'is']

其他:

  1、sort()配合lambda()进行排序:

1 l = [[2, 2, 3], [1, 4, 5], [5, 4, 9]]
2  l.sort(lambda x:x[0])  ##按照第一个元素进行排序
3 print(l)   ##输出:[[1, 4, 5], [2, 2, 3], [5, 4, 9]]
4 '''
5     匿名函数的x,表示的是l列表中的每一个成员元素
6     
7     x[0] :表示列表里面列表的第一个成员元素
8 '''

   2、也可以对对对象的属性进行排序

2、sorted()方法

 1 def sorted(*args, **kwargs): # real signature unknown
 2     """
 3     Return a new list containing all items from the iterable in ascending order.
 4     
 5     A custom key function can be supplied to customize the sort order, and the
 6     reverse flag can be set to request the result in descending order.
 7     """
 8 '''
 9 sorted(L)返回一个排序后的L,不改变原始的L;
  L.sort()是对原始的L进行操作,调用后原始的L会改变,没有返回值。【所以a = a.sort()是错的啦!a = sorted(a)才对!
11 sorted()适用于任何可迭代容器,list.sort()仅支持list(本身就是list的一个方法)
12 
13 '''

 1、sort配合lambda进行排序

 2、sort配合lambda进行排序

  若是可迭代序列的成员元素是对象,那么同样可以用sorted方法进行排序: 对象.成员变量

 1 >>> class Student:
 2         def __init__(self, name, grade, age):
 3                 self.name = name
 4                 self.grade = grade
 5                 self.age = age
 6         def __repr__(self):
 7                 return repr((self.name, self.grade, self.age))
 8 >>> student_objects = [
 9         Student('john', 'A', 15),
10         Student('jane', 'B', 12),
11         Student('dave', 'B', 10),
12 ]
13 >>> sorted(student_objects, key=lambda student: student.age)   # sort by age
14 [('dave', 'B', 10), ('jane', 'B', 12), ('john', 'A', 15)]

 3、如果第一个排序条件相同,则按照第二个条件排序

a = [[2,3],[4,1],(2,8),(2,1),(3,4)]
b = sorted(a,key=lambda x: (x[0], -x[1]))
print(b)
'''
  b = sorted(a,key=lambda x:(条件a,条件b))  
'''

 4、字典排序:

#厂商报价字典
vendorQuote = {"A":32.5, "B":32.5, "C":19.5}

排序写法:按照v字段排序,排序结果为包含元组对象的列表。可以按照列表的方式进行遍历:
l_sorted = sorted(vendorQuote.items(),key = lambda k: k[1]) #加reverse = True表示从大到小,默认从小到大

#l_sorted结果为:[('fuze', 19.5), ('yintuo', 32.5), ('kunlun', 32.5)]
minPrice = l_sorted[0][1]
secminPrice = l_sorted[1][1]

 5、字典的key-values互换

1 dic = { 'a':1, 'b':2,'c':3}
2 # 字典生成式
3 {values:key for key,values in dic.items()} ## 记住dic.items()变成了items[('a',1),('b',1)]

6、自定义排序

原文:python3 sorted 如何自定义排序标准_python重写sort的key-CSDN博客

实例代码:解决这道题目:登录—专业IT笔试面试备考平台_牛客网

import functools #需导入该包

#自定义排序方法,以下a,b都是字符串,主要比较ab前后拼接后的结果
def cmp(a, b):
    if a + b >  b + a:
        return 1 #
    if a  + b < b + a:
        return -1 #
    return 0
n = input()
n_list = input().split()

n_list2 = sorted(n_list, key=functools.cmp_to_key(cmp), reverse=True)
res = ''
for s in n_list2:
          res = res + s
print(res)

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值