一文搞懂Python sorted() 函数

sorted() 是 Python 中用于排序的内置函数,它能够对各种可迭代对象进行排序并返回一个新的有序列表。与列表的 sort() 方法不同,sorted() 不会修改原对象,而是返回一个新的排序后的列表。

一、基本语法

sorted(iterable, *, key=None, reverse=False)

参数说明:

  • iterable:要排序的可迭代对象(列表、元组、字符串、字典、集合等)
  • key:指定排序依据的函数(默认为 None,即直接比较元素本身)
  • reverse:排序顺序,False 表示升序(默认),True 表示降序

二、基础用法

2.1 对列表排序

numbers = [3, 1, 4, 1, 5, 9, 2]
sorted_numbers = sorted(numbers)
print(sorted_numbers)  # 输出: [1, 1, 2, 3, 4, 5, 9]
print(numbers)         # 输出: [3, 1, 4, 1, 5, 9, 2] (原列表不变)

2.2 对字符串排序

text = "python"
sorted_text = sorted(text)
print(sorted_text)  # 输出: ['h', 'n', 'o', 'p', 't', 'y']
print(''.join(sorted_text))  # 输出: "hnopty"

2.3 对元组排序

tuples = [(1, 'b'), (2, 'a'), (1, 'a')]
sorted_tuples = sorted(tuples)
print(sorted_tuples)  # 输出: [(1, 'a'), (1, 'b'), (2, 'a')]

三、高级用法

3.1 使用 key 参数自定义排序

key 参数接受一个函数,该函数将应用于每个元素,然后根据函数返回的结果进行排序。

按字符串长度排序
words = ["banana", "pie", "apple", "orange"]
sorted_words = sorted(words, key=len)
print(sorted_words)  # 输出: ['pie', 'apple', 'banana', 'orange']
按字典的值排序
students = [
    {
   
   'name'
### Python `sorted()` 函数详解 `sorted()` 是 Python 中的一个内置函数,能够对任何可迭代的对象进行排序并返回一个新的已排序列表[^1]。 #### 参数说明 该函数接受三个参数: - **iterable**: 可迭代对象,如列表、元组或集合等。 - **key (optional)**: 一个用来指定排序依据的一元函数,默认为 None。 - **reverse (optional)**: 布尔值,如果设置为 True,则按降序排列;默认情况下为 False 表示升序排列[^2]。 #### 返回值 总是返回一个新的列表,其中包含了按照特定顺序排列的元素副本。原始序列不会被修改。 #### 实际应用实例 以下是几个使用 `sorted()` 的具体例子来展示如何利用这些特性: ```python # 对简单的整数列表进行排序 numbers = [5, 2, 9, 1, 7] print(sorted(numbers)) # 输出: [1, 2, 5, 7, 9] # 使用 key 参数自定义排序逻辑 words = ['apple', 'banana', 'cherry'] print(sorted(words, key=len)) # 按字符串长度排序: ['apple', 'cherry', 'banana'] # 设置 reverse=True 来实现降序排序 scores = [(80, 'Alice'), (95, 'Bob'), (88, 'Charlie')] print(sorted(scores, key=lambda item: item[0], reverse=True)) # 根据分数高低排序后的结果: [(95, 'Bob'), (88, 'Charlie'), (80, 'Alice')] # 排序字典项基于键或值 from operator import itemgetter d = {'a': 3, 'b': 1, 'c': 2} print(sorted(d.items(), key=itemgetter(1))) # 按照字典值从小到大排序: [('b', 1), ('c', 2), ('a', 3)] ``` 通过上述代码片段可以清楚看到 `sorted()` 如何灵活应用于不同类型的数据结构之上,并且可以通过调整参数来自由控制排序行为。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值