如有错误欢迎指正
一、前言
对Python的列表(list)有两个用于排序的方法:
一个是内建方法list.sort(),可以直接改变列表的内容:
>>> list1 = [9,8,7,6,5]>>>list1.sort()>>>list1
[5, 6, 7, 8, 9]
另一个是内建函数sorted(),它的特点是不改变原列表的内容,而是根据一个可迭代对象建立一个新的列表:
>>> list2 = [4,3,2,1]>>> list3 =sorted(list2)>>>list2
[4, 3, 2, 1]>>>list3
[1, 2, 3, 4]
二、基础排序
最简单的升序排序非常容易:直接调用sorted()函数就可以了,它返回一个新的列表:
>>> sorted([5, 2, 3, 1, 4])
[1, 2, 3, 4, 5]
也可以使用列表本身的方法list.sort()去排序。它会改变list的内容,然后返回None作为执行的结果,以避免混淆。一般来说它没有sorted()那么方便,但是如果你不需要原来的列表的话,使用它在性能上会有轻微的提升。
>>> a = [5, 2, 3, 1, 4]>>>a.sort()>>>a
[1, 2, 3, 4, 5]
另一个区别就是,list.sort()方法只能用于列表,相对的,sorted()函数则适用于所有的可迭代对象,如:
>>> sorted({1: 'D', 2: 'B', 3: 'B', 4: 'E', 5: 'A'})
[1, 2, 3, 4, 5]
五、升序和降序
list.sort()和sorted()都接受一个reverse参数,这个参数的取值是一个布尔值,用来标记是否降序排序。例如,用age字段降序排列去获取学生信息:
>>> sorted(student_tuples, key=itemgetter(2), reverse=True)
[('john', 'A', 15), ('jane', 'B', 12), ('dave', 'B', 10)]
>>> sorted(student_objects, key=attrgetter('age'), reverse=True)
[('john', 'A', 15), ('jane', 'B', 12), ('dave', 'B', 10)]
如有错误欢迎指正