Python 中的列表排序和排序规则

Python 中的列表排序和排序规则

在 Python 中,列表的排序是一个常见的操作,可以使用内置函数 sorted() 或列表对象的 sort() 方法来完成。下面将介绍这两种方法以及排序规则的使用方式。

1. 使用 sorted() 函数排序列表(临时性排序)

sorted() 函数接受一个可迭代对象作为参数,并返回一个新的已排序的列表,而不修改原始列表。示例如下:

my_list = [3, 1, 4, 1, 5, 9, 2, 6, 5]
sorted_list = sorted(my_list)
print(sorted_list)  # 输出:[1, 1, 2, 3, 4, 5, 5, 6, 9]
2. 使用 sort() 方法对列表进行排序(永久性排序)

sort() 方法用于直接修改原始列表,并按照指定的排序规则对其进行排序。示例如下:

my_list = [3, 1, 4, 1, 5, 9, 2, 6, 5]
my_list.sort()
print(my_list)  # 输出:[1, 1, 2, 3, 4, 5, 5, 6, 9]
3. 指定排序规则

如果想要根据特定规则进行排序,可以使用 key 参数来指定一个函数,该函数将应用于列表中的每个元素,并用于生成排序依据。
存在相同的排序依据(例如,对字符串列表按长度排序,有多个字符串具有相同的长度),那么 Python 将按照原始列表中元素的顺序来保持这些相同元素的相对位置不变
例如,按照字符串长度排序:

my_list = ["banana","grape", "apple", "orange", "kiwi"]
sorted_list = sorted(my_list, key=len)
print(sorted_list)  # 输出:['kiwi', 'grape', 'apple', 'banana', 'orange']
4. 默认排序规则

Python 中默认的排序规则是按照元素的自然顺序进行排序。对于数字类型,自然顺序是从小到大排序;对于字符串类型,自然顺序是按照字典顺序进行排序。

my_list = [3, 1, 4, 1, 5, 9, 2, 6, 5]
sorted_list = sorted(my_list)
print(sorted_list)  # 输出:[1, 1, 2, 3, 4, 5, 5, 6, 9]

my_list = ["banana", "apple", "orange"]
sorted_list = sorted(my_list)
print(sorted_list)  # 输出:['apple', 'banana', 'orange']

通过以上方法,可以在 Python 中对列表进行灵活的排序,并根据需要定义排序规则。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值