Python中排序主要用sort()和sorted(),前者原地修改列表返回None,后者返回新列表不改变原数据,根据是否需保留原顺序选择方法。

Python 中对 list 进行排序主要有两种方法:使用 sort() 方法和使用 sorted() 函数。它们都能实现排序,但有一些关键区别。
list.sort() 是列表对象的一个方法,它直接修改原列表,不返回新列表,返回值为 None。
适合在不需要保留原始顺序时使用。
list.sort(key=None, reverse=False)
示例:
立即学习“Python免费学习笔记(深入)”;
nums = [3, 1, 4, 1, 5] nums.sort() print(nums) # 输出: [1, 1, 3, 4, 5] <p>words = ['banana', 'apple', 'cherry'] words.sort(key=len) # 按字符串长度排序 print(words) # 输出: ['apple', 'banana', 'cherry']</p>
sorted() 是一个内置函数,可以对任何可迭代对象排序,返回一个新的排序后的列表,原列表不变。
适合需要保留原始数据顺序的场景。
sorted(iterable, key=None, reverse=False)
示例:
立即学习“Python免费学习笔记(深入)”;
nums = [3, 1, 4, 1, 5]
new_nums = sorted(nums, reverse=True)
print(new_nums) # 输出: [5, 4, 3, 1, 1]
print(nums) # 原列表未变: [3, 1, 4, 1, 5]
<p>data = [('Alice', 25), ('Bob', 20), ('Charlie', 30)]
sorted_data = sorted(data, key=lambda x: x[1]) # 按年龄排序
print(sorted_data) # 输出: [('Bob', 20), ('Alice', 25), ('Charlie', 30)]</p>sorted(words, key=len)
sorted(words, key=str.lower)
sorted(dict_list, key=lambda x: x['age'])
key=lambda x: (x[0], x[1])
基本上就这些。根据是否要修改原列表来选择用 sort() 还是 sorted(),再配合 key 和 reverse 实现灵活排序。
以上就是python的list排序方法的详细内容,更多请关注php中文网其它相关文章!
python怎么学习?python怎么入门?python在哪学?python怎么学才快?不用担心,这里为大家提供了python速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号