当前位置:主页 > 软件编程 > Python代码 >

python列表排序用 sort()和sorted()的区别

时间:2022-07-10 09:38:47 | 栏目:Python代码 | 点击:

前言:

内容提要:本文比较了 Python 中用于列表排序的两种函数 sort() 和 sorted(),帮助您选择合适的排序函数。

对列表排序时,既可以用 List.sort(),也可以用 sorted(List),这两个函数有什么不同呢?如何选择?我以前常常分不清这两个函数,等到程序报错了,才知道 sorted 写成 sort 了,List 不能写在 sort() 括号里。您是否也有这个困惑呢?那就一起通过例子来熟悉这两个函数吧,以后就知道应该怎么使用了。

1. 是否改变原列表

首先应用 List.sort() 对列表排序,

代码示例如下:

letters=['a','dc','ab','D']
print('before sort: letters:',letters)
result1=letters.sort()
print('after sort: result1:',result1)
print('after sort: letters:',letters)

运行结果为:

before sort: letters: ['a', 'dc', 'ab', 'D']
after sort: result1: None
after sort: letters: ['D', 'a', 'ab', 'dc']

可以看到,List.sort() 没有返回值,而是直接改变了原列表。这既是优点也是缺点。说它是优点呢,有时不需要再使用原列表,直接修改原列表可以节约内存空间,尤其当这个列表很大时。而它的缺点也正是因为改了原列表,新手在程序设计时容易忽视这一点,在后续程序中错误地操作列表,导致得不到预计的结果。

再来看一下应用 sorted(List) 对列表排序的效果,

代码示例如下:

letters=['a','dc','ab','D']
print('before sorted: letters:',letters)
result2=sorted(letters)
print('after sorted: result2:',result2)
print('after sorted: letters:',letters)

运行结果为:

before sorted: letters: ['a', 'dc', 'ab', 'D']
after sorted: result2: ['D', 'a', 'ab', 'dc']
after sorted: letters: ['a', 'dc', 'ab', 'D']

可以看到,sorted(List) 返回一个排序好的新列表,原列表不变。

依据上述对比,在选择排序函数时,我们需要考虑两点:

2.参数设置:key 和 reverse

看上面例子中列表 letters 的排序结果,发现 D 居然排在 a 的前面?这是因为 ASCII 码中大写英文字母排在小写英文字母的前面。那么,如果我们想实现按字母顺序,不区分大小写的排序,应该怎么办呢?

方法:可以设置 key 参数,对 sort() 和 sorted() 都适用。

比如:设置key=str.lower,就是按字符的小写字母形式排序。

代码示例如下:

letters=['a','dc','ab','D']
letters.sort(key=str.lower)
print(letters)

运行结果为:

['a', 'ab', 'D', 'dc']

此外,默认是按升序排列。也可以设置reverse=True,就是按降序排列。这一参数同样是对 sort() 和 sorted() 都适用。下面的代码示例同时设置了 key 和 reverse 参数。

letters=['a','dc','ab','D']
result=sorted(letters,key=str.lower,reverse=True)
print(result)

运行结果为:

['dc', 'D', 'ab', 'a']

3.输入数据类型

List.sort() 是列表对象(object)的一个方法(method),因此只能用于列表。

sorted() 函数是 Python 语言的内置函数,可以用于 iterables,包括 列表(List),元组(Tuple),字典(Dict)等等。iterable 对象有一个特点,就是可以用在循环 for 语句中(例如上面例子的列表 letters,可以用在 for 语句中:for e in letters:)。

下面我们来看看不同数据类型应用 sorted() 函数的例子。需要注意的是,虽然 sorted() 的输入可以有多种类型,但是输出都是排序好的列表。

输入为元组(Tuple)时:

letters=('a','dc','ab','D')
result=sorted(letters)
print(result)

运行结果为:

['D', 'a', 'ab', 'dc']

输入为字符串(Str)时:

letters='dasf'
result=sorted(letters)
print(result)

运行结果为:

['a', 'd', 'f', 's']

从结果可以看出,输入为字符串时,输出为排序好的字符列表,单个字符为列表的一个元素。

输入为字典(Dict)时:

letters={'b':1,'a':3,'d':2,'c':1}
result=sorted(letters)
print(result)

运行结果为:

['a', 'b', 'c', 'd']

从结果可以看出,sorted() 函数输出的结果是对letters.key() 排序得到的列表。

参考:https://docs.python.org/3/howto/sorting.html

您可能感兴趣的文章:

相关文章