列表list的sort方法的坑

说明

列表sort方法是原地排序即会修改原列表。在日常工作中遇到一些坑,总结在示例里

 

示例

复制代码
 1 '''
 2 sort是原地排序即会修改原列表
 3 '''
 4 
 5 # 1. 原地排序,没有新增列表,只是修改了原列表。如果遇到保留原始列表,可通过切片生成1个新的
 6 my_list = [3, 1, 2, 5, 4]
 7 sorted_list = my_list.sort()
 8 print(sorted_list)  # Output: None
 9 # 由于sort()方法是原地排序,它会直接修改原始列表,并且不返回任何结果
10 print(my_list)  # [1, 2, 3, 4, 5]
11 
12 # 2. 可变对象的排序
13 my_list = [[3], [1], [2], [5], [4]]
14 my_list.sort()
15 # 这会有一种错觉,是按照列表中的元素:1,2,3,4,5排序,其实不是
16 '''
17 在这个示例中,列表my_list包含多个嵌套的可变对象(子列表)。
18 默认情况下,sort()方法会按照列表元素的自然顺序进行排序。
19 但是,如果列表中的元素是可变对象,则排序仅影响到对象的引用,而不是实际的值。因此,在这个示例中,子列表的排序是根据其内存地址进行的,而不是子列表中的数字。
20 '''
21 print(my_list)  # Output: [[1], [2], [3], [4], [5]]
22 
23 # 3. 自定义排序规则
24 my_list = ['apple', 'banana', 'Orange']
25 my_list.sort()
26 print(my_list)  # Output: ['Orange', 'apple', 'banana']
27 
28 # sort()方法按照字母的ASCII码值进行排序,默认情况下,大写字母会优先于小写字母。
29 # 如果想要忽略大小写进行排序,可以使用key=str.lower参数。
30 my_list = ['apple', 'banana', 'Orange']
31 my_list.sort(key=str.lower)  # 通过key指定排序规则
32 print(my_list)  # Output: ['apple', 'banana', 'Orange']
33 
34 # 4. 降序,默认是升序
35 my_list = [3, 1, 2, 5, 4]
36 my_list.sort(reverse=True)
37 print(my_list)  # Output: [5, 4, 3, 2, 1]
38 
39 # 5. 排序稳定性:Python的排序算法(Timsort)是稳定的,即相等元素的相对顺序在排序后保持不变。
40 # 这意味着如果有多个元素具有相同的排序键(例如数字相同),它们将按照它们在原始列表中的顺序进行排列。
41 my_list = [(3, 'apple'), (2, 'banana'), (3, 'Orange')]
42 my_list.sort()
43 print(my_list)  # Output: [(2, 'banana'), (3, 'apple'), (3, 'Orange')],升序排列时(3, 'apple')永远排在(3, 'Orange')之前
44 
45 
46 # 6. 可变对象作为默认参数:当将可变对象(如列表或字典)作为函数的默认参数时,它只会在函数被定义时创建一次。
47 # 如果在函数中修改了该默认参数,则下一次调用函数时会继续使用修改后的默认参数值。
48 def append_item(item, my_list=[]):
49     my_list.append(item)
50     return my_list
51 
52 
53 print(append_item(1))  # Output: [1]
54 print(append_item(2))  # Output: [1, 2] (unexpected result)
55 
56 # 7. sort与sorted 2个方法的区别
57 # 1. 归属不一样:sort()是一个列表方法,而sorted()是一个内置函数。
58 # 2. 调用方式不一样: 列表对象.sort()方法,而sorted()是sorted(列表对象),当然是sorted也可以用在元组、字符串。
59 # 3. 原列表是否修改:sort()是原地排序,即它会直接修改原始列表,并且不返回任何结果。而sorted()会返回一个新的已排序的列表,而不会改变原始列表
60 my_list = [3, 1, 2]
61 my_list.sort(reverse=True)
62 print(my_list)  # Output: [3, 2, 1]
63 
64 my_list = [3, 1, 2]
65 sorted_list = sorted(my_list, reverse=True)
66 print(sorted_list)  # Output: [3, 2, 1]
67 print(my_list)  # Output: [3, 1, 2]
复制代码

 

posted @   Allen_Hao  阅读(67)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
点击右上角即可分享
微信分享提示