Python中的sort()与sorted()用法

Python中的sort()函数主要用于对列表(list)中的元素进行排序。它有两种形式:一种是列表的方法(即直接对列表对象调用),另一种则是内置的sorted()函数,它返回一个新的已排序列表,而不改变原始列表。

列表的sort()方法

使用列表的sort()方法时,它会直接修改原列表,使其元素按照升序(从小到大)排列。

基本用法

python 复制代码
my_list = [3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5]  
my_list.sort()  
print(my_list)  # 输出:[1, 1, 2, 3, 3, 4, 5, 5, 5, 6, 9]

参数

  • reverse=True:降序排序
  • key:用于比较的函数,例如按照字符串长度排序或按照元素的某个属性排序

示例

降序排序:

python 复制代码
my_list = [3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5]  
my_list.sort(reverse=True)  
print(my_list)  # 输出:[9, 6, 5, 5, 5, 4, 3, 3, 2, 1, 1]

使用key参数:

假设我们有一个包含字典的列表,我们想要根据字典中的某个值进行排序:

python 复制代码
data = [{'name': 'Alice', 'age': 25}, {'name': 'Bob', 'age': 20}, {'name': 'Charlie', 'age': 23}]  
data.sort(key=lambda item: item['age'])  
print(data)  
# 输出:[{'name': 'Bob', 'age': 20}, {'name': 'Charlie', 'age': 23}, {'name': 'Alice', 'age': 25}]

内置的sorted()函数

sorted()函数接受一个可迭代对象(如列表、元组等)作为输入,并返回一个新的已排序列表。原列表不会被修改。

基本用法

python 复制代码
my_list = [3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5]  
sorted_list = sorted(my_list)  
print(sorted_list)  # 输出:[1, 1, 2, 3, 3, 4, 5, 5, 5, 6, 9]  
print(my_list)  # 输出:[3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5],原列表未被修改

参数

sorted()函数的参数与sort()方法相同,包括reversekey

总之,sort()sorted()在功能上是相似的,主要区别在于前者会修改原列表,而后者会返回一个新的已排序列表。根据你的具体需求选择使用哪个函数。

相关推荐
wabs6667 小时前
关于贪心算法的思考
算法·贪心算法
社交怪人7 小时前
【判断大小】信息学奥赛一本通C语言解法(题号1043)
算法
许彰午7 小时前
14_Java泛型完全指南
java·windows·python
Snasph8 小时前
GNU Make 用户手册(中文版)
服务器·算法·gnu
广州灵眸科技有限公司8 小时前
瑞芯微RV1126B开发板(EASY-EAI-PI2) Easy-Eai编译环境准备与更新
服务器·前端·人工智能·python·深度学习
江澎涌8 小时前
拆解与 AI 的一次对话
人工智能·算法·程序员
TechWayfarer8 小时前
IP风险等级评估接入实战:金融信贷如何用IP画像辅助风控审核
python·tcp/ip·安全·金融
Esaka_Forever8 小时前
uv init 完整用法(Python 最快包管理器)
服务器·python·uv
sheeta19988 小时前
LeetCode 每日一题笔记 日期:2026.06.02 题目:3635. 最早完成陆地和水上游乐设施的时间 II
笔记·算法·leetcode
Lsk_Smion9 小时前
力扣实训 _ [102].层序遍历--前序--后续_递归与非递归的实现
数据结构·算法·leetcode