Python排序之sorted

作者: 翎月 | 来源:发表于2016-01-19 00:37 被阅读642次
Python要对list迭代序列的排序,提供了两种方法:
  • list的成员函数sort()排序
  • 内建函数sorted()排序
    以上两个函数的区别除了一个事内建函数、一个是list成员函数外,还主要有以下区别
  • sortedsort灵活,排序方法丰富
  • sorted是产生一个新的列表,sort是在原位重新排列列表
sorted()官方定义:
>>> help(sorted)
Help on built-in function sorted in module __builtin__:
sorted(...)
sorted(iterable, cmp=None, key=None, reverse=False) --> new sorted list
  • iterable:可迭代序列
  • cmp:用于比较的函数,比较什么由key决定,有默认值,迭代集合中的一项;
  • key: 用列表元素的某个属性用 cmp函数 进行作为关键字,有默认值,迭代集合中的一项;
  • reverse:升降序排列,默认为升序
下面举例来说明:
  • sort排序
    >>> L = [5, 2, 4, 1, 3]
    >>> L.sort()
    >>> L
    [1, 2, 3, 4, 5]

  • sorted排序
    >>> L = [5, 2, 4, 1, 3]
    >>> sorted(L)
    [1, 2, 3, 4, 5]

  • sorted方法之reverse
    >>> L = [5, 2, 4, 1, 3]
    >>> sorted(L,reverse=True)
    [5, 4, 3, 2, 1]

  • sorted方法之cmp:
    >>> L = [('b',2),('a',1),('c',3),('d',4)]
    >>> sorted(L,cmp=lambda x,y:cmp(x[1],y[1]))
    [('a', 1), ('b', 2), ('c', 3), ('d', 4)]
    -sorted方法之key(效率key>cmp(key比cmp快)):
    >>> L = [('b',2),('f',5),('e',3),('d',4),('c',1)]
    >>> sorted(L,key=lambda x:x[0])
    [('b', 2), ('c', 1), ('d', 4), ('e', 3), ('f', 5)]
    >>> sorted(L,key=lambda x:x[1])
    [('c', 1), ('b', 2), ('e', 3), ('d', 4), ('f', 5)]

  • sorted方法之key:对list先按照第二个关键字来排序,再按照第一个关键字来排序
    >>> L = [('b',2),('f',5),('e',3),('d',4),('c',1)]
    >>> sorted(L,key=lambda x:(x[1],x[0]))
    [('c', 1), ('b', 2), ('e', 3), ('d', 4), ('f', 5)]

  • sorted方法对dict排序
    >>> import operator
    >>> x = {1:2, 3:4, 4:3, 2:1, 0:0}
    >>> sorted(x.iteritems(), key=operator.itemgetter(1))
    [(0, 0), (2, 1), (1, 2), (4, 3), (3, 4)]
    >>> sorted(x.iteritems(), key=operator.itemgetter(0))
    [(0, 0), (1, 2), (2, 1), (3, 4), (4, 3)]

  • x.items()是把所有字典的项按照列表形式返回,x.iteritems()返回的是一个迭代器

  • operator.itemgetter:operator模块提供的itemgetter函数用于获取对象的哪些维的数据,参数为一些序号(即需要获取的数据在对象中的序号),如:
    >>> a = [1,2,3]
    >>> b = operator.itemgetter(1) //定义函数b,获取对象的第1个域的值
    >>> b(a)
    2
    备注:operator.itemgetter函数获取的不是值,而是定义了一个函数,通过该函数作用到对象上才能获取值。

  • sorted对包含dict的list排序
    >>> x = [{'name':'Homer', 'age':39}, {'name':'Bart', 'age':10}]
    >>> sorted(x,key=operator.itemgetter('name'))
    [{'age': 10, 'name': 'Bart'}, {'age': 39, 'name': 'Homer'}]
    >>> sorted(x,key=operator.itemgetter('age'),reverse=True)
    [{'age': 39, 'name': 'Homer'}, {'age': 10, 'name': 'Bart'}]

以上就是Python的list排序。

相关文章

网友评论

    本文标题:Python排序之sorted

    本文链接:https://www.haomeiwen.com/subject/ccbkkttx.html