python

关注公众号 jb51net

关闭
首页 > 脚本专栏 > python > Python列表排序方法

Python对列表进行排序的五种方法示例代码

作者:kdayjj966

这篇文章主要给大家介绍了关于Python对列表进行排序的五种方法,分别是sort()、sorted()、lambda表达式、reverse()和自定义排序算法,这些方法各有特点,文中给出了详细的代码示例,需要的朋友可以参考下

前言

在 Python 中,排序是一个非常常见且重要的操作,尤其是对列表的排序。Python 提供了多种方法来实现排序操作,从内置函数到自定义排序逻辑,都可以方便地满足不同的需求。以下将介绍 Python 对列表进行排序的 5 种方法,并配以示例代码。

方法 1:使用 sort() 方法(原地排序)

list.sort() 是列表的一个内置方法,它会直接对列表本身进行排序(即原地排序,不会返回新的列表)。它支持两种可选参数:

特点:

示例代码:

# 示例 1:默认升序排序
nums = [5, 2, 9, 1, 5, 6]
nums.sort()  # 原地排序
print(nums)  # 输出:[1, 2, 5, 5, 6, 9]

# 示例 2:降序排序
nums = [5, 2, 9, 1, 5, 6]
nums.sort(reverse=True)
print(nums)  # 输出:[9, 6, 5, 5, 2, 1]

# 示例 3:基于字符串长度排序
words = ["apple", "banana", "kiwi", "cherry"]
words.sort(key=len)
print(words)  # 输出:['kiwi', 'apple', 'cherry', 'banana']

方法 2:使用 sorted() 函数(返回新列表)

sorted() 是一个内置函数,用于对可迭代对象进行排序。与 sort() 不同,sorted() 不会修改原列表,而是返回一个新的排序后的列表。

特点:

示例代码:

# 示例 1:默认升序排序
nums = [5, 2, 9, 1, 5, 6]
sorted_nums = sorted(nums)
print(sorted_nums)  # 输出:[1, 2, 5, 5, 6, 9]
print(nums)         # 原列表不变,输出:[5, 2, 9, 1, 5, 6]

# 示例 2:降序排序
nums = [5, 2, 9, 1, 5, 6]
sorted_nums = sorted(nums, reverse=True)
print(sorted_nums)  # 输出:[9, 6, 5, 5, 2, 1]

# 示例 3:基于自定义规则排序
words = ["apple", "banana", "kiwi", "cherry"]
sorted_words = sorted(words, key=len)
print(sorted_words)  # 输出:['kiwi', 'apple', 'cherry', 'banana']

方法 3:使用 lambda 表达式进行自定义排序

无论是 sort() 还是 sorted(),都可以通过 key 参数指定排序依据。这里常使用 lambda 表达式来定义自定义排序规则。

特点:

示例代码:

# 基于元组的第二个元素排序
data = [(1, 3), (4, 1), (2, 2), (3, 4)]
data.sort(key=lambda x: x[1])  # 按元组的第二个元素排序
print(data)  # 输出:[(4, 1), (2, 2), (1, 3), (3, 4)]

# 按字符串的最后一个字母排序
words = ["apple", "banana", "kiwi", "cherry"]
sorted_words = sorted(words, key=lambda x: x[-1])  # 按单词最后一个字母排序
print(sorted_words)  # 输出:['banana', 'apple', 'cherry', 'kiwi']

方法 4:使用 reverse() 方法倒序排列

reverse() 是列表的一个内置方法,用于将列表中的元素顺序颠倒。需要注意,它不是真正的排序,而是直接将当前顺序反转。

特点:

示例代码:

# 示例:将列表倒序排列
nums = [1, 2, 3, 4, 5]
nums.reverse()
print(nums)  # 输出:[5, 4, 3, 2, 1]

方法 5:自定义排序算法

当内置的 sort() 或 sorted() 无法满足需求时,可以实现自己的排序算法(如冒泡排序、快速排序等)。以下以 冒泡排序 为例。

特点:

示例代码:冒泡排序

def bubble_sort(nums):
    n = len(nums)
    for i in range(n):
        for j in range(0, n-i-1):
            if nums[j] > nums[j+1]:  # 比较相邻的元素
                nums[j], nums[j+1] = nums[j+1], nums[j]  # 交换位置

# 测试代码
nums = [5, 2, 9, 1, 5, 6]
bubble_sort(nums)
print(nums)  # 输出:[1, 2, 5, 5, 6, 9]

总结与对比

方法适用场景是否修改原列表灵活性性能表现
sort()原地排序,不需要保存原列表较高快速(Timsort 算法)
sorted()保留原列表,生成新排序列表较高快速(Timsort 算法)
lambda 自定义排序需要复杂规则排序的场景可选非常高依赖于 sort() 或 sorted()
reverse()简单倒序排列一般快速
自定义排序算法学习排序原理或特殊场景可选非常高根据实现算法而定

最佳实践建议

通过以上 5 种方法,你可以轻松地对列表进行排序,满足各种实际需求!

到此这篇关于Python对列表进行排序的五种方法的文章就介绍到这了,更多相关Python列表排序方法内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文