• 技术文章 >后端开发 >Python教程

    浅谈Python中的排序

    PHP中文网PHP中文网2017-06-21 15:25:42原创541

    浅谈排序

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

    1、参数

    函数原型:

    sort([cmp[, key[, reverse]]])

    、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

      

     

    php入门到就业线上直播课:查看学习

    以上就是浅谈Python中的排序的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。

    前端(VUE)零基础到就业课程:点击学习

    清晰的学习路线+老师随时辅导答疑

    自己动手写 PHP MVC 框架:点击学习

    快速了解MVC架构、了解框架底层运行原理

    专题推荐:Python sort 排序 笔记 开发
    上一篇:ubuntu16.04设置python3为默认及一些库的安装 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • ❤️‍🔥共22门课程,总价3725元,会员免费学• ❤️‍🔥接口自动化测试不想写代码?• Python NumPy教程之数据类型对象• 使用Python处理KNN分类算法• Python标准库中的logging用法示例• python发腾讯微博代码分享• 在Django的视图(View)外使用Session的方法
    1/1

    PHP中文网