python sort 和 sorted

1、list 的内置 sort() 方法

在原有list上做操作,改变了原有list

class list(object):
      def sort(self, cmp=None, key=None, reverse=False):
         pass

示例:

# -*- coding: utf-8 -*-
if __name__ == '__main__':
    a = [2, 1, 4, 5, 3]
    a.sort()
    print a

输出:
[1, 2, 3, 4, 5] 

2、sorted()

def sorted(iterable, cmp=None, key=None, reverse=False):
    pass

示例:

# -*- coding: utf-8 -*-
if __name__ == '__main__':
    a = [2, 1, 4, 5, 3]
    b = sorted(a)
    print a
    print b

输出:
[2, 1, 4, 5, 3]        # a
[1, 2, 3, 4, 5]        # b

3、自定义排序方式及参数详解

以下参数对sort和sorted用法及含义都一样。

key

这两种排序都是通过key这个参数来指向排序方式的。

# -*- coding: utf-8 -*-

def my_sort(data):
    return data.get('num')

if __name__ == '__main__':
    a = [
        {'num': 10, 'date': '2017-10-01'},
        {'num': 9, 'date': '2017-10-02'},
        {'num': 12, 'date': '2017-10-03'}
    ]

    print '1: ', sorted(a, key=my_sort)      # TODO
    # print 'sorted a: ', sorted(a, key=lambda data: data.get('num'))        # 排序方式简单可采用匿名函数方式, 含义同上
    
    print '2: ', a

    a.sort(key=my_sort)
    print '3 : ', a

输出:
1:  [{'date': '2017-10-02', 'num': 9}, {'date': '2017-10-01', 'num': 10}, {'date': '2017-10-03', 'num': 12}]
2:  [{'date': '2017-10-01', 'num': 10}, {'date': '2017-10-02', 'num': 9}, {'date': '2017-10-03', 'num': 12}]
3:  [{'date': '2017-10-02', 'num': 9}, {'date': '2017-10-01', 'num': 10}, {'date': '2017-10-03', 'num': 12}]

key指向一个函数,可以是普通函数也可以是匿名函数。而这个指向的函数的参数就是列表的一个元素,排序的结果就是根据每次这个函数的返回值进行排的。

以上面的 TODO 例子说明, 列表a进行迭代:
第一次传入 {'num': 10, 'date': '2017-10-01'} ,my_sort 返回 10
第二次传入 {'num': 9, 'date': '2017-10-02'} ,my_sort 返回 9
第三次传入 {'num': 12, 'date': '2017-10-03'} ,my_sort 返回 12

然后根据10,9, 12 对列表a进行排序,得到最后的结果。

reverse

反序

a = [3, 4, 1, 2, 5]
print sorted(a)
>>> [1, 2, 3, 4, 5]

print sorted(a, reverse=True)
>>> [5, 4, 3, 2, 1]
cmp

两个元素的比较函数。python3中已经移除,并且,key参数基本替代cmp。

特别补充:

sorted 对 dict排序:返回的是一个元素为元祖的列表

a = {'time1': '2017-00-01 12:12:12', 'time2': '2017-01-01 12:12:12'}
print sorted(a.items(), key=lambda item: item[1], reverse=True)

>>> [('time2', '2017-01-01 12:12:12'), ('time1', '2017-00-01 12:12:12')]    # 注意这里的格式
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 文:郑元春一个有着美好梦想的coder! 人生苦短,我用Python。 P.S. 个人认为,查找和排序是算法的核心...
    北静王阅读 6,471评论 3 10
  • 数据结构,是指通过某种方式(例如对元素进行编号)组织在一起的数据元素的集合,这些数据元素可以是数字或者字符,甚至可...
    千释炎阅读 4,326评论 0 0
  • 一、基本数据类型 注释 单行注释:// 区域注释:/* */ 文档注释:/** */ 数值 对于byte类型而言...
    龙猫小爷阅读 9,789评论 0 16
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 33,653评论 18 399
  • 上外松外五年级8班 王玥颖 今年暑假,我有幸跟着学校的游学团去了英国。其中我感触最大,印象最深的就是英国的泰晤士河...
    jungwong阅读 3,247评论 0 0

友情链接更多精彩内容