zoukankan      html  css  js  c++  java
  • 【笔记】:sort排序大法

    浅谈排序

    程序中经常用到排序函数,Python 提供了 sort 和 sorted 函数,一个原地排序,一个返回排序后的新结果

    1、参数

    函数原型:

    sort([cmp[, key[, reverse]]])
    • 意思是sort方法接受三个参数,都可以省略,默认是升序排序。
    • 第一个参数cmp 是 比较函数,两个参数(列表的元素)怎样比较,对于整数这种内置类型的比较,方法很直观,但是对于自定义类型的比较,就要自己定义比较函数了,函数返回 0 ,就是两个数相等,返回负数,就是第一个参数小,第一个参数就排在第二个参数后面了。
    • 第二个参数 key 是比较列表元素的什么属性。
    • 第三个参数reverse是bool型,意思是是否反转(倒序排序)

    、cmp参数示例:

    #cmp 函数,两个数倒过来比较 注!只能在python2.0上运行
    s = [1, 2, 3, 4, 5]
    s.sort(cmp=lambda a, b:cmp(b, a))
    print s
    # [5, 4, 3, 2, 1]

    ②、常用参数key,reverse使用方法,代码:

    # key 指定排序方式  reverse 是否反排序
    
    li = ['x11','abc323','e26','112ddd','fstgd2']
    
    li.sort(key=len,reverse=True)    # 用长度进行排序,从大到小进行排序
    print(li)
    # ['abc323', '112ddd', 'fstgd2', 'x11', 'e26']
    
    li.sort(key=lambda x:x[-1])     # key可以指定lambada函数x为列表中每个元素
    print(li)                       # 元素的最后一个字符进行排序
    # ['x11', 'fstgd2', 'abc323', 'e26', '112ddd']
    
    li = zip(range(10),range(10)[::-1])  # 列表中元素为元祖是排序
    print(li,type(li))
    # <zip object at 0x000000E7F75504C8> <class 'zip'>
    li = list(li)
    print(li)
    # [(0, 9), (1, 8), (2, 7), (3, 6), (4, 5), (5, 4), (6, 3), (7, 2), (8, 1), (9, 0)]
    li.sort(key=lambda x:x[-1])
    print(li)
    # [(9, 0), (8, 1), (7, 2), (6, 3), (5, 4), (4, 5), (3, 6), (2, 7), (1, 8), (0, 9)]
    
    #**注!默认sort也是会对列表中元祖进行排序的
    li.sort()
    print(li)
    # (0, 9), (1, 8), (2, 7), (3, 6), (4, 5), (5, 4), (6, 3), (7, 2), (8, 1), (9, 0)]
    

    参数key可以是:key=int,key=len, key=lambda...  

    2、排序

    、如何按照 value 从小到大输出 dict 中的 key-value值?

    dic = {'z':1, 'y':4,'x':2,'g':3,'sg':3}
    
    dic= sorted(dic.items(),key=lambda x:x[1])
    print(dic)
    # [('z', 1), ('x', 2), ('sg', 3), ('g', 3), ('y', 4)]
    

    排序后转换为字典:

    from collections import OrderedDict
    
    dic = {'z':1, 'y':4,'x':2,'g':3,'sg':3}
    dic= OrderedDict(sorted(dic.items(),key=lambda x:x[1]))
    
    print dic
    # OrderedDict([('z', 1), ('x', 2), ('sg', 3), ('g', 3), ('y', 4)])
    for k,v in dic.items():
        print k,v
    # z 1
    # x 2
    # sg 3
    # g 3
    # y 4
    

    给定一个只包含大小写字母,数字的字符串,对其进行排序,保证:

    • 所有的小写字母在大写字母前面
    • 所有的字母在数字前面
    • 所有的奇数在偶数前面
    s = "Sorting1234"
    
    def sort_str(x):     # x 传入的每个元素
        if x.isdigit():
            if int(x) % 2 == 0:
                return (4,x)    # 返回的是元祖,元祖可进行排序
            return (3,x)
        elif x.islower():
            return (0,x)
        elif x.isupper():
            return (1,x)
    
    li = sorted(s,key=sort_str)
    print(li)
    # ['g', 'i', 'n', 'o', 'r', 't', 'S', '1', '3', '2', '4']
    string = ''.join(li)
    print(string)
    # ginortS1324

    更简洁的代码:

    s = "Sorting1234"
    
    s ="".join(sorted(s, key=lambda x: (x.isdigit(), x.isdigit() and int(x) % 2 == 0, x.isupper(), x.islower(), x)))
    print(s)
    # ginortS1324
    

      

     

  • 相关阅读:
    【mysql】sum处理null的结果
    【ELK】【docker】6.Elasticsearch 集群启动多节点 + 解决ES节点集群状态为yellow
    【ELK】5.spring boot日志集成ELK,搭建日志系统
    【MySQL】EXPLAIN命令详解--解释执行计划
    【java】ThreadLocal线程变量的实现原理和使用场景
    【工具类】根据IP获取IP归属地,国家,城市信息
    【POI】maven引用POI的依赖,XSSFWorkbook依旧无法使用的问题。
    Spring Boot 2实现分布式锁——这才是实现分布式锁的正确姿势!
    frp服务搭建
    RedisTemplate的key默认序列化器问题
  • 原文地址:https://www.cnblogs.com/lianzhilei/p/6932894.html
Copyright © 2011-2022 走看看