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]
时间: 2024-10-14 01:30:16

python 列表排序方法reverse、sort、sorted基础篇的相关文章

Python 列表排序方法reverse、sort、sorted详解

python语言中的列表排序方法有三个:reverse反转/倒序排序.sort正序排序.sorted可以获取排序后的列表.在更高级列表排序中,后两中方法还可以加入条件参数进行排序. reverse()方法 将列表中元素反转排序,比如下面这样 1 2 3 4 >>> x = [1,5,2,3,4] >>> x.reverse() >>> x [4, 3, 2, 5, 1] reverse列表反转排序:是把原列表中的元素顺序从左至右的重新存放,而不会对列表

python:列表的方法

注意:在列表的类方法一般是没有返回值的,如果将处理过的列表给新变量,新变量是空类型.如:>>>a=[1,2]>>>b=a.append(3)>>>type(b)>>>None 1.添加元素(append,extend,insert):list.append(obj):在列表末尾添加新的对象list.extend(seq):在列表末尾一次性追加另一个序列中的多个值(用新列表扩展原来的列表)append,extend两者的区别:>&

Python 列表 insert() 方法

目录 描述 语法 参数 返回值 实例 正文 回到顶部 描述 Python 列表 insert() 方法将指定对象插入到列表中的指定位置. 回到顶部 语法 insert() 方法语法: 1 L.insert(index,obj) 回到顶部 参数 index -- 对象obj需要插入的索引值. obj -- 要插入列表中的对象. 回到顶部 返回值 该方法没有返回值,但会在列表指定位置插入指定对象. 回到顶部 实例 以下实例展示了 insert() 方法的使用方法: 1 2 3 4 5 #!/usr/

Python列表排序 reverse、sort、sorted 操作方法详解

reverse()方法 将列表中元素反转排序,比如下面这样>>> x = [1,5,2,3,4]>>> x.reverse()>>> x[4, 3, 2, 5, 1]reverse列表反转排序:是把原列表中的元素顺序从左至右的重新存放,而不会对列表中的参数进行排序整理.如果需要对列表中的参数进行整理,就需要用到列表的另一种排序方式sort正序排序. sort()排序方法 此函数方法对列表内容进行正向排序,排序后的新列表会覆盖原列表(id不变),也就是s

python 列表排序

转自http://www.iplaypython.com/jinjie/jj114.html reverse()方法 将列表中元素反转排序,比如下面这样>>> x = [1,5,2,3,4]>>> x.reverse()>>> x[4, 3, 2, 5, 1]reverse列表反转排序:是把原列表中的元素顺序从左至右的重新存放,而不会对列表中的参数进行排序整理.如果需要对列表中的参数进行整理,就需要用到列表的另一种排序方式sort正序排序. sort(

Python列表函数&方法

Python包含以下函数: 序号 函数 1 cmp(list1, list2)比较两个列表的元素 2 len(list)列表元素个数 3 max(list)返回列表元素最大值 4 min(list)返回列表元素最小值 5 list(seq)将元组转换为列表 Python包含以下方法: 序号 方法 1 list.append(obj)在列表末尾添加新的对象 2 list.count(obj)统计某个元素在列表中出现的次数 3 list.extend(seq)在列表末尾一次性追加另一个序列中的多个值

python列表的方法(改变原列表)

xxx.append()      末尾添加一个元素效果图: 代码: # append() 末尾添加一个元素 my_list = ['1','2','3','4'] print('原列表:',my_list) my_list.append('five') print('现列表:',my_list) xxx.insert()     向指定位置插入元素效果图: 代码: # insert() 向指定位置插入元素 my_list = ['1','2','3','4'] print('指定插入前',my

python列表的方法

1.append 字列表末尾追加新的对象 >>>lst=[1,2,3] >>>lst.append(4) >>>lst [1,2,3,4] 2.count 用于计算某个元素在列表中出现的次数 >>>['to','be','or','not','to','be','this','is','a','question'].count('to') 2 3.extend 即使用一个b列表,来扩展a列表,注意,a列表会被改变. >>&

python 列表分组方法

def page(li, num): """ :param li: 需要分页的列表 :param num: 每一页页码数量 :return: 分页后列表 需要导入math模块 """ zu = math.ceil(len(li)/num) new_list = [] n = 0 while True: if n == (zu - 1): new_list.append(li3[n:]) break page = li3[n:(n + num)]