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

Python中对列表排序主要有两种方式:使用sort()方法和
sorted()函数。它们都能实现排序,但使用场景和效果有所不同。1. list.sort() 方法 — 原地排序
该方法直接在原列表上进行排序,不返回新列表,而是修改原有列表。
特点:
- 改变原始列表
- 没有返回值(返回None)
- 适用于不需要保留原顺序的场景
示例:
立即学习“Python免费学习笔记(深入)”;
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() 函数 — 返回新列表
该函数会创建一个排序后的新列表,原始列表保持不变。
特点:
不修改原列表返回一个新的排序列表适用于需要同时保留原数据和排序结果的情况
示例:
立即学习“Python免费学习笔记(深入)”;
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']
基本上就这些。根据是否需要保留原列表来选择用哪种方式。不复杂但容易忽略细节。
以上就是python列表排序的两种方式的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1379158.html
微信扫一扫
支付宝扫一扫