在你创建的列表中元素的排列顺序常常是无法预测的,因为你并非总能控制用户提供数据的顺序。这虽然在大多数情况下都是不可避免的,但你经常需要以特定的顺序呈现信息。有时候,你希望保留列表元素最初的排列顺序,而有时又需要调整排列顺序。python提供了很多组织列表的方式,可根据具体情况选用。
python大大的图
我的图
1.使用方法sort()对列表进行永久性排序
sort()默认按照升序进行排序。先排每个元素的第一位,如果第一位相同,再排第二位。纯数字和纯字母都这么排,如果数字和字母混在一起,先数字后字母
其实sort()这个函数不仅仅可以按升序排序。我们来看看它的原型:
sort(fun,key,reverse=False)
参数fun是表明此sort函数是基于何种算法进行排序的,一般默认情况下python中用的是归并排序,并且一般情况下我们是不会重写此参数的,所以基本可以忽略;
参数key用来指定一个函数,此函数在每次元素比较时被调用,此函数代表排序的规则,也就是你按照什么规则对你的序列进行排序;
参数reverse是用来表明是否逆序,默认的False情况下是按照升序的规则进行排序的,当reverse=True时,便会按照降序进行排序。
下面用key来写一个低配函数来了解一下sort的排序功能有多强大
key可以写成不同的表达式,通常是lambda,当然也可以事先人为定义一个函数。lambda后面可以写正则表达式,实现很复杂的排序。
2.使用函数sorted()对列表进行临时排序
要保留列表元素原来的排列顺序,同时以特定的顺序呈现它们,可使用函数sorted(),函数sorted()让你能够按特定的顺序显示列表元素,同时不影响它们在列表中的原始排列顺序。
sorted()的原型为:
sorted(iterable,cmp=None,key=None,reverse=False)
iterable是可迭代对象,可以是字符串,列表,字典,元组。
cmp不怎么用,因为key和reverse比单独一个cmp效率要高。
key和前面的key一样,可以让这个函数有非常花的排序方式。
reverse也是和前面一样,决定可迭代对象要不要降序的一个关键参数。
sorted() 和list.sort() 都接受key, reverse定制。但是区别是:list.sort()是列表中的方法,只能用于列表。而sorted可以用于任何可迭代的对象。list.sort()是在原序列上进行修改,不会产生新的序列。所以如果你不需要旧的序列,可以选择list.sort()。 sorted() 会返回一个新的序列。旧的对象依然存在。
这里需要解释一下大大代码里的第10行,即第4个print。我们知道sort()是对代码永久排序,那么在前两个print之后,这个列表已经被永久的修改成了第二个print的结果。此时,第三个print是对列表临时升序排列,暂时改变了列表的样子,但是列表并没有被它改变,紧接着第四个print就证明了列表并没有被sorted()改变。
这个章节有一个注意说大写字母排序得到的顺序可能不准确。我试了一下,没有影响啊,可能没有遇到特例吧。如果真的受影响,可以考虑用函数lower()把字母全都转为小写再排序。
3.倒着打印列表
要反转列表元素的排列顺序,可使用方法reverse()。注意:reverse()并不是指按与字母顺序相反的顺序排列列表元素,而只是反转列表元素的排列顺序。方法reverse()永久性的修改列表元素的排列顺序,但可随时恢复到原来的排列顺序,为此只需对列表再次调用reverse()即可。
由此看来,reverse()和sort(reverse=True)的区别就很明显了。reverse()是反转列表元素的排列顺序,而sort(reverse=True)是把列表元素按字母降序排列。单独拿出来再看一下就知道了。
4.确定列表长度
这个len()我们已经用过很多次了,用在for循环里的range(len(list))。使用函数len()可以快速获悉列表长度。python计算列表元素时从1开始,而不是从0开始。因此确定列表长度时,你应该不会遇到差一错误。