Python【sort函数正则表达式】

Python【sort函数正则表达式】


最近老是遇到使用python的sort函数时忘记怎么写排序规则的情况,这里好好整理一下。

1.sort函数最简单的用法

最简单的就是利用sort函数对一维列表进行排序:

l = [99, 55, 66, 10, 80]

l.sort()

print(l)

输出:

[10, 55, 66, 80, 99]

2.sort函数reverse

如果需要降序排序,那么可以给sort函数的reverse设置成True:

l = [99, 55, 66, 10, 80]

l.sort(reverse=True)

print(l)

输出:

[99, 80, 66, 55, 10]

3.自定义比较函数

如果列表当中的每一个元素都是一个列表,即算法竞赛当中经常遇到的二维数组这种情况,那么上面两种写法就都不适用了。熟悉C++的都知道,在C++中可以自定义一个cmp函数来指定自己的排序规则,那么在python当中也可以这样:

l = [[2,1], [1,3],[3,0]]

def cmp(x):
    # 这里表示按照每个元素的第0个元素来排序
    return x[0]

l.sort(key=cmp)

print(l)

输出:

[[1, 3], [2, 1], [3, 0]]

4.自定义比较函数plus

如果比较的规则更复杂,比如优先按照第0个元素进行比较,然后按照第1个元素比较,这种情况只需要在cmp函数当中返回一个元组就可以了:

l = [[2,1,1], [2,0,3],[1,2,0],[3,-10,-10]]

def cmp(x):
    # 这里表示先按照第0个元素,再按照第一个元素
    return (x[0],x[1])

l.sort(key=cmp)

print(l)

输出:

[[1, 2, 0], [2, 0, 3], [2, 1, 1], [3, -10, -10]]

5.正则表达式

可以看到排序规则写起来有点麻烦,还需要重新写一个排序函数,如果有多个数组需要这样排序,可能还会写多个排序规则。在python中还可以用正则表达式来写排序规则:

l = [[2,1,1], [2,0,3],[1,2,0],[3,-10,-10]]

l.sort(key = lambda x : (x[0], x[1]))

print(l)

输出:

[[1, 2, 0], [2, 0, 3], [2, 1, 1], [3, -10, -10]]
  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Alan_Lowe

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值