zoukankan      html  css  js  c++  java
  • python排序 sorted()与list.sort() (转)

    该文章为转载;原文地址为:https://www.cnblogs.com/zuizui1204/p/6422939.html

    只要是可迭代对象都可以用sorted 。

    sorted(itrearble, cmp=None, key=None, reverse=False)

    =号后面是默认值 默认是升序排序的, 如果想让结果降序排列,用reverse=True

    最后会将排序的结果放到一个新的列表中, 而不是对iterable本身进行修改。

    eg:

    1, 简单排序

    sorted('123456')  字符串

    ['1', '2', '3', '4', '5', '6']

    sorted([1,4,5,2,3,6])  列表
    [1, 2, 3, 4, 5, 6]

    sorted({1:'q',3:'c',2:'g'}) 字典, 默认对字典的键进行排序
    [1, 2, 3]

     sorted({1:'q',3:'c',2:'g'}.keys())  对字典的键
    [1, 2, 3]

    sorted({1:'q',3:'c',2:'g'}.values())  对字典的值
    ['c', 'g', 'q']

    sorted({1:'q',3:'c',2:'g'}.items())  对键值对组成的元组的列表
    [(1, 'q'), (2, 'g'), (3, 'c')]

    2, 对元素指定的某一部分进行排序,关键字排序

    s = ['Chr1-10.txt','Chr1-1.txt','Chr1-2.txt','Chr1-14.txt','Chr1-3.txt','Chr1-20.txt','Chr1-5.txt']

    我想要按照-后的数字的大小升序排序。要用到key

    sorted(s, key=lambda d : int(d.split('-')[-1].split('.')[0]))

    ['Chr1-1.txt', 'Chr1-2.txt', 'Chr1-3.txt', 'Chr1-5.txt', 'Chr1-10.txt', 'Chr1-14.txt', 'Chr1-20.txt']

    这就是key的功能,制定排序的关键字,通常都是一个lambda函数,当然你也可以事先定义好这个函数。如果不讲这个关键字转化为整型,结果是这样的:

    sorted(s, key=lambda d : d.split('-')[-1].split('.')[0])

    ['Chr1-1.txt', 'Chr1-10.txt', 'Chr1-14.txt', 'Chr1-2.txt', 'Chr1-20.txt', 'Chr1-3.txt', 'Chr1-5.txt']

    这相当于把这个关键字当做字符串了,很显然,在python中,'2' > '10'

    多属性排序: 

    list.sort(key=lambda x: (x.left_text, x.label), reverse=True)

     3,cmp不怎么用,因为key和reverse比单独一个cmp效率要高。

    如果进行降序排列,只需要加上reverse=True

    总结: sorted 和list.sort 都接受key, reverse定制。但是区别是。list.sort()是列表中的方法,只能用于列表。而sorted可以用于任何可迭代的对象。list.sort()是在原序列上进行修改,不会产生新的序列。所以如果你不需要旧的序列,可以选择list.sort()。 sorted() 会返回一个新的序列。旧的对象依然存在。

  • 相关阅读:
    多线程编程(二)--进程&&线程
    hdu2222 Keywords Search
    sqlserver 运行正則表達式,调用c# 函数、代码
    【Nutch2.2.1基础教程之2.2】集成Nutch/Hbase/Solr构建搜索引擎之二:内容分析
    ios学习之block初探
    PHP GD 生成图片验证码+session获取储存验证码
    ps 命令详解
    python --subprocess
    python --存储对象
    python --字符串格式化
  • 原文地址:https://www.cnblogs.com/ying-chease/p/9390141.html
Copyright © 2011-2022 走看看