使用 sorted() 函数可实现不修改原列表的排序,而 sort() 方法则直接修改原列表;2. 通过 key 参数指定排序键,如用 lambda 或函数定义排序依据,支持复杂排序逻辑;3. key 可返回元组实现多级排序,如先按年龄再按姓名;4. sorted() 更灵活通用,适用于各种可迭代对象,而 sort() 仅用于列表且原地排序;5. 选择取决于是否需保留原列表及性能考量,两者算法相同,差异主要在内存使用。

Python中,你可以用函数实现列表的排序,这提供了一种更灵活、可控的排序方式,而不是仅仅依赖内置的
sort()
方法。
解决方案
直接使用
sorted()
函数,或者自定义排序逻辑。
立即学习“Python免费学习笔记(深入)”;
# 使用 sorted() 函数my_list = [3, 1, 4, 1, 5, 9, 2, 6]sorted_list = sorted(my_list) # 默认升序print(sorted_list) # 输出: [1, 1, 2, 3, 4, 5, 6, 9]# 自定义排序规则def my_sort_key(x): return x % 3 # 例如,按模3的结果排序sorted_list_custom = sorted(my_list, key=my_sort_key)print(sorted_list_custom) # 输出可能为: [3, 6, 9, 1, 1, 4, 2, 5] (顺序取决于具体数据)# 使用 lambda 表达式简化 key 的定义sorted_list_lambda = sorted(my_list, key=lambda x: x % 3)print(sorted_list_lambda)# 降序排序sorted_list_reverse = sorted(my_list, reverse=True)print(sorted_list_reverse) # 输出: [9, 6, 5, 4, 3, 2, 1, 1]
sorted()
函数返回一个新的排序后的列表,而不会修改原始列表。 如果你想原地排序,可以使用列表的
sort()
方法,但它不能像
sorted()
那样灵活地使用
key
参数。
如何利用
key
key
参数实现复杂排序?
key
参数允许你指定一个函数,该函数接受列表中的每个元素作为输入,并返回一个用于排序的“键”。 这个键可以是任何可比较的值,例如数字、字符串,甚至元组。
举个例子,假设你有一个包含字符串的列表,你想忽略大小写进行排序:
string_list = ["apple", "Banana", "orange", "grape"]sorted_string_list = sorted(string_list, key=str.lower)print(sorted_string_list) # 输出: ['apple', 'Banana', 'grape', 'orange']
这里,
str.lower
函数被用作
key
,它将每个字符串转换为小写,然后再进行比较。 所以,”Banana” 在排序时会被当作 “banana” 处理。
更复杂的情况,假设你有一个包含元组的列表,每个元组包含姓名和年龄,你想先按年龄排序,再按姓名排序:
people = [("Alice", 30), ("Bob", 25), ("Charlie", 30), ("David", 20)]sorted_people = sorted(people, key=lambda person: (person[1], person[0])) # 先按年龄,再按姓名print(sorted_people) # 输出: [('David', 20), ('Bob', 25), ('Alice', 30), ('Charlie', 30)]
注意
key
函数返回的是一个元组
(person[1], person[0])
。 Python 会按照元组的顺序进行比较,所以首先比较年龄,如果年龄相同,则比较姓名。
sort()
sort()
方法和
sorted()
函数有什么区别,应该选择哪个?
sort()
是列表的一个方法,它会直接修改原始列表,将其原地排序。 它没有返回值(或者说返回
None
)。
sorted()
是一个内置函数,它接受任何可迭代对象作为输入,返回一个新的排序后的列表,而不会修改原始对象。
选择哪个取决于你的需求:
如果需要修改原始列表,并且不需要保留原始顺序,可以使用
sort()
。 这样做通常更节省内存,因为它不需要创建新的列表。
如果需要保留原始列表的顺序,或者需要对其他类型的可迭代对象(例如元组、集合、字典的视图)进行排序,应该使用
sorted()
。
sorted()
更加通用。
另外,
sorted()
可以接受
key
和
reverse
参数,提供更灵活的排序选项。 虽然
sort()
方法也接受这两个参数,但使用
sorted()
通常更清晰易懂。
一个常见的误解是
sort()
比
sorted()
更快。 实际上,对于列表来说,它们的排序算法是相同的(Timsort),主要的性能差异在于
sort()
是原地操作,而
sorted()
需要创建新的列表。 如果已经有一个列表,并且不需要保留原始顺序,
sort()
可能会略微快一些,但这种差异通常可以忽略不计。
以上就是Python函数如何用函数实现列表的简单排序 Python函数列表排序的基础应用技巧的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1367728.html
微信扫一扫
支付宝扫一扫