登录
首页 >  文章 >  python教程

Python列表排序方法详解

时间:2025-11-09 22:18:39 428浏览 收藏

想要高效排序Python列表?本文为你详细解读`list.sort()`方法和`sorted()`函数这两种常用的排序方式。`list.sort()`方法直接修改原列表,实现原地排序,不返回新列表,适合无需保留原始数据的场景。而`sorted()`函数则会创建一个新的已排序列表,原始列表保持不变,更适用于需要同时保留原数据和排序结果的情况。两者都支持`reverse`参数控制升序或降序,以及`key`参数自定义排序规则。本文将通过实例代码,深入解析它们的特点、用法和适用场景,助你根据实际需求,选择最合适的Python列表排序方法,提升代码效率。

Python中列表排序有两种方式:1. list.sort()方法原地排序,直接修改原列表,无返回值;2. sorted()函数创建新列表,不改变原列表。两者均支持reverse和key参数,根据是否需保留原数据选择使用。

python列表排序的两种方式

Python中对列表排序主要有两种方式:使用sort()方法和sorted()函数。它们都能实现排序,但使用场景和效果有所不同。

1. list.sort() 方法 — 原地排序

该方法直接在原列表上进行排序,不返回新列表,而是修改原有列表。

特点:

  • 改变原始列表
  • 没有返回值(返回None
  • 适用于不需要保留原顺序的场景

示例:

numbers = [3, 1, 4, 1, 5]
numbers.sort()
print(numbers)  # 输出: [1, 1, 3, 4, 5]
<h1>降序排列</h1><p>numbers.sort(reverse=True)
print(numbers)  # 输出: [5, 4, 3, 1, 1]</p>

2. sorted() 函数 — 返回新列表

该函数会创建一个排序后的新列表,原始列表保持不变。

特点:

  • 不修改原列表
  • 返回一个新的排序列表
  • 适用于需要同时保留原数据和排序结果的情况

示例:

words = ['banana', 'apple', 'cherry']
sorted_words = sorted(words)
print(sorted_words)  # 输出: ['apple', 'banana', 'cherry']
print(words)         # 输出: ['banana', 'apple', 'cherry'](原列表未变)
<h1>支持任意可迭代对象</h1><p>sorted_tuple = sorted((3, 1, 2))
print(sorted_tuple)  # 输出: [1, 2, 3]</p>

两者都支持reverse参数控制升序或降序,也支持key参数自定义排序规则,比如按字符串长度排序:

names = ['Alice', 'Bob', 'Charlie']
sorted_names = sorted(names, key=len)
print(sorted_names)  # 输出: ['Bob', 'Alice', 'Charlie']

基本上就这些。根据是否需要保留原列表来选择用哪种方式。不复杂但容易忽略细节。

以上就是《Python列表排序方法详解》的详细内容,更多关于的资料请关注golang学习网公众号!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>