Python 列表排序要领reverse、sort、sorted详解
python语言中的列表排序要领有三个:reverse反转/倒序排序、sort正序排序、sorted可以获取排序后的列表。在更高级列表排序中,后两中要领还可以插手条件参数举办排序。
reverse()要领
将列表中元素反转排序,好比下面这样
>>> x = [1,5,2,3,4] >>> x.reverse() >>> x [4, 3, 2, 5, 1]
reverse列表反转排序:是把原列表中的元素顺序从左至右的从头存放,而不会对列表中的参数举办排序整理。假如需要对列表中的参数举办整理,就需要用到列表的另一种排序方法sort正序排序。
sort()排序要领
此函数要领对列表内容举办正向排序,排序后的新列表会包围原列表(id稳定),也就是sort排序要领是直接修改原列表list排序要领。
>>> a = [5,7,6,3,4,1,2] >>> a.sort() >>> a [1, 2, 3, 4, 5, 6, 7]
很多python初学者,对sort()要领较量糊涂。有的时候会需要一个排序好的列表,而又想生存原有未排序列表,他们会这么操纵:
>>> a = [5,7,6,3,4,1,2] >>> b = a.sort() >>> print b None
这个时候问题呈现了,变量b获得的是一个空值。那么想要获得排序好的列表,又想保存原列表怎么办呢?列表sorted()要领可以帮你实现。
sorted()要领
即可以保存原列表,又能获得已经排序好的列表sorted()操纵要领如下:
>>> a = [5,7,6,3,4,1,2] >>> b = sorted(a) >>> a [5, 7, 6, 3, 4, 1, 2] >>> b [1, 2, 3, 4, 5, 6, 7]
sorted()要领可以用在任何数据范例的序列中,返回的老是一个列表形式:
>>> sorted('iplaypython.com') ['.', 'a', 'c', 'h', 'i', 'l', 'm', 'n', 'o', 'o', 'p', 'p', 't', 'y', 'y']
三者的区别
sort()是可变工具(字典、列表)的要领,无参数,无返回值,sort()会改变可变工具,因此无需返回值。sort()要领是可变工具独占的要领可能属性,而作为不行变工具如元组、字符串是不具有这些要领的,假如挪用将会返回一个异常。
>>> a=[5,4,3,2,1] >>> a.sort() >>> >>> a [1, 2, 3, 4, 5]
sorted()是python的内置函数,并不是可变工具(列表、字典)的特有要领,sorted()函数需要一个参数(参数可以是列表、字典、元组、字符串),无论通报什么参数,都将返回一个以列表为容器的返回值,假如是字典将返回键的列表。
>>> mystring="54321" >>> mytuple=(5,4,3,2,1) >>> mylist=[5,4,3,2,1] >>> sorted(mystring) ['1', '2', '3', '4', '5'] >>> sorted(mytuple) [1, 2, 3, 4, 5] >>> sorted(mylist) [1, 2, 3, 4, 5]
reverse()与sort的利用方法一样,而reversed()与sorted()的利用方法沟通
>>> mylist=[5,4,3,2,1] >>> mylist.reverse() >>> mylist [1, 2, 3, 4, 5] >>> mylist=[5,4,3,2,1] >>> for i in reversed(mylist): ... print i, ... 1 2 3 4 5
通过序列的切片也可以到达“逆转”的结果
>>> mystring="54321" >>> mytuple=(5,4,3,2,1) >>> mylist=[5,4,3,2,1] >>> mystring[::-1] '12345' >>> mytuple[::-1] (1, 2, 3, 4, 5) >>> mylist[::-1] [1, 2, 3, 4, 5]