题目:
对一个列表进行排序
错误的解法
>>> lst=[9,2,6,4,1]
>>> lst
[9, 2, 6, 4, 1]
>>> y=lst.sort()
>>> y
>>>
list的sort是本地排序的,返回的是None,所以结果lst是排序后的列表,y是None。
相似的原因,下面的做法也是错的
>>> lst=[9,2,6,4,1]
>>> lst
[9, 2, 6, 4, 1]
>>> (lst.sort()).reverse()
Traceback (most recent call last):
File "<pyshell#10>", line 1, in <module>
(lst.sort()).reverse()
AttributeError: 'NoneType' object has no attribute 'reverse'
也就是方法不能连用了。
那么我们就知道sort方法的特点了:1是本地排序,2是返回None,这样我们就需要处理一些问题了。
不想本地排序怎么办
最容易想到的办法是使用另一个变量
>>> x=lst
>>> x.sort()
>>> x
[1, 2, 4, 6, 9]
>>> lst
[1, 2, 4, 6, 9]
这里我们发现,虽然使用了另一个变量依然改变了原来的值,这是因为我们等号传递的是地址。那么我们如果想使用另一变量解决本地排序的问题可以用下面的方法做。
>>> lst=[9,2,6,4,1]
>>> x=lst[:]
>>> x.sort()
>>> lst
[9, 2, 6, 4, 1]
>>> x
[1, 2, 4, 6, 9]
当然我们也可以使用一个sorted函数(不是list的方法,而是一个内建函数)
>>> lst=[9,2,6,4,1]
>>> y=sorted(lst)
>>> lst
[9, 2, 6, 4, 1]
>>> y
[1, 2, 4, 6, 9]
这个函数不是本地排序的,而是把结果的list返回出来。
这个sorted内建函数和reversed内建函数有点像,不过reversed内建函数返回的reverse iterator对象,sorted返回的是一个列表。
>>> z=reversed(lst)
>>> z
<list_reverseiterator object at 0x0000000003BC5BE0>
>>> list(z)
[1, 4, 6, 2, 9]
两个可选参数
函数指针型key与布尔型reverse
>>> lst.sort(key = lambda x:-1*x)
>>> lst
[9, 6, 4, 2, 1]
>>> lst.sort(key = lambda x:-1*x,reverse=True)
>>> lst
[1, 2, 4, 6, 9]
版权声明:本文为博主原创文章,欢迎转载和分享,但请声明出处
http://blog.csdn.net/zhzz2012/article/details/47958453