Python 中的列表排序和排序规则
在 Python 中,列表的排序是一个常见的操作,可以使用内置函数 sorted()
或列表对象的 sort()
方法来完成。下面将介绍这两种方法以及排序规则的使用方式。
1. 使用 sorted()
函数排序列表(临时性排序)
sorted()
函数接受一个可迭代对象作为参数,并返回一个新的已排序的列表,而不修改原始列表。示例如下:
my_list = [3, 1, 4, 1, 5, 9, 2, 6, 5]
sorted_list = sorted(my_list)
print(sorted_list) # 输出:[1, 1, 2, 3, 4, 5, 5, 6, 9]
2. 使用 sort()
方法对列表进行排序(永久性排序)
sort()
方法用于直接修改原始列表,并按照指定的排序规则对其进行排序。示例如下:
my_list = [3, 1, 4, 1, 5, 9, 2, 6, 5]
my_list.sort()
print(my_list) # 输出:[1, 1, 2, 3, 4, 5, 5, 6, 9]
3. 指定排序规则
如果想要根据特定规则进行排序,可以使用 key
参数来指定一个函数,该函数将应用于列表中的每个元素,并用于生成排序依据。
存在相同的排序依据(例如,对字符串列表按长度排序,有多个字符串具有相同的长度),那么 Python 将按照原始列表中元素的顺序来保持这些相同元素的相对位置不变
例如,按照字符串长度排序:
my_list = ["banana","grape", "apple", "orange", "kiwi"]
sorted_list = sorted(my_list, key=len)
print(sorted_list) # 输出:['kiwi', 'grape', 'apple', 'banana', 'orange']
4. 默认排序规则
Python 中默认的排序规则是按照元素的自然顺序进行排序。对于数字类型,自然顺序是从小到大排序;对于字符串类型,自然顺序是按照字典顺序进行排序。
my_list = [3, 1, 4, 1, 5, 9, 2, 6, 5]
sorted_list = sorted(my_list)
print(sorted_list) # 输出:[1, 1, 2, 3, 4, 5, 5, 6, 9]
my_list = ["banana", "apple", "orange"]
sorted_list = sorted(my_list)
print(sorted_list) # 输出:['apple', 'banana', 'orange']
通过以上方法,可以在 Python 中对列表进行灵活的排序,并根据需要定义排序规则。