Python中列表排序有两种方式:1. list.sort()方法原地排序,直接修改原列表,无返回值;2. sorted()函数创建新列表,不改变原列表。两者均支持reverse和key参数,根据是否需保留原数据选择使用。
Python中对列表排序主要有两种方式:使用sort()方法和
sorted()函数。它们都能实现排序,但使用场景和效果有所不同。1. list.sort() 方法 — 原地排序
该方法直接在原列表上进行排序,不返回新列表,而是修改原有列表。
特点:
- 改变原始列表
- 没有返回值(返回None)
- 适用于不需要保留原顺序的场景
示例:
numbers = [3, 1, 4, 1, 5] numbers.sort() print(numbers) # 输出: [1, 1, 3, 4, 5]降序排列
numbers.sort(reverse=True) print(numbers) # 输出: [5, 4, 3, 1, 1]
2. sorted() 函数 — 返回新列表
该函数会创建一个排序后的新列表,原始列表保持不变。
特点:
- 不修改原列表
- 返回一个新的排序列表
- 适用于需要同时保留原数据和排序结果的情况
示例:
words = ['banana', 'apple', 'cherry'] sorted_words = sorted(words) print(sorted_words) # 输出: ['apple', 'banana', 'cherry'] print(words) # 输出: ['banana', 'apple', 'cherry'](原列表未变)支持任意可迭代对象
sorted_tuple = sorted((3, 1, 2)) print(sorted_tuple) # 输出: [1, 2, 3]
两者都支持reverse参数控制升序
或降序,也支持key参数自定义排序规则,比如按字符串长度排序:
names = ['Alice', 'Bob', 'Charlie'] sorted_names = sorted(names, key=len) print(sorted_names) # 输出: ['Bob', 'Alice', 'Charlie']
基本上就这些。根据是否需要保留原列表来选择用哪种方式。不复杂但容易忽略细节。








