【Python】python技能树之包含元祖的列表升降序

文章讲述了在Python中如何对包含元组的列表进行复杂排序,特别是当元组内元素是字符串时,如何实现按第一个元素升序,第二个元素降序排序。通过自定义类`Reversor`重写比较魔术方法实现这一目标。此外,还提及了Python中对象可比较性基于`__eq__`,`__lt__`等魔术方法。
摘要由CSDN通过智能技术生成


前言

大家都知道,在Python里面可以使用.sort方法或者sorted函数对各种数据进行排序,例如:

一、实际操作

a = [2, 3, 1, 9, 3, 7, 4]
a.sort()
b = [2, 3, 1, 9, 3, 7, 4]
c = sorted(b, reverse=True)
运行效果如下图所示:

在这里插入图片描述
我们也知道,Python中的元组是可以比较大小的。它的比较方法就是先对第一个元素比较,如果第一个元素相等,再比较第二个元素。因此对包含元组的列表也可以这样排序,例如:

d = [(6, 5), (1, 3), (4, 7), (6, 4), (1, 8), (7, 9)]
d.sort()
在这里插入图片描述
但现在问题来了,如果要对这个列表排序,但是需要对元组中的第一个元素升序,第二个元素降序,应该怎么办呢?

之前有一个很简单的算法题:输入一串字符串,输出出现次数最高的3个字母:

s = 'asgaurghajsfa;oeiwfasdfasdgrwerw'
count = {}
for letter in s:
    count.setdefault(letter, 0)
    count[letter] += 1

result = sorted(count.items(), key=lambda x: x[1], reverse=True)
print('出现频率最高的3个字母分别是:', result[:3])

运行效果如下图所示:
在这里插入图片描述
如果你做过这个算法题,那么你肯定知道怎么做。只需要设置key参数就可以了。在第二个元素前面加个负号:

d = [(6, 5), (1, 3), (4, 7), (6, 4), (1, 8), (7, 9)]
e = sorted(d, key=lambda x: (x[0], -x[1]))
运行效果如下图所示:
在这里插入图片描述
现在问题来了,如果被排序的列表里面的元组第二项,不是数字,而是字符串怎么办?字符串前面又不能加负号啊。

例如对如下列表进行排序,按元组第一个元素升序,第二个元素降序:

[(6, ‘apple’), (1, ‘google’), (4, ‘future’), (6, ‘zero’), (1, ‘stand’), (7, ‘t’)]
可能有同学会想到,可以把字符转成Ascii码再来加负号。这个方法对单个字符确实可行,但是当字符串有多个字符时,这样做就显得很麻烦了。

为了解决这个问题,我们需要回想一下,为什么在Python里面,有一些对象可以比大小,另一些对象却不行?为什么字符串可以比大小,数字可以比大小,但是当我自定义一个类,然后生成对象的时候,却不能比大小?

在这里插入图片描述

二、使用步骤

Python里面能比较大小的对象,是因为他们的类里面有一类特殊的魔术方法:__eq__用来判断是否相等,__lt__用来判断是否小于,__gt__来判断是否大于……,例如:

import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
import seaborn as sns
import warnings
warnings.filterwarnings('ignore')
import  ssl
ssl._create_default_https_context = ssl._create_unverified_context

在这里插入图片描述
这样一来,如果想要倒序,只需要把__lt__里面的逻辑反过来就可以了:
在这里插入图片描述

我们再来写一下排序函数,对于需要倒序的位置使用这个自定义的类包一下:

class Reversor:
    def __init__(self, value):
        self.value = value
    
    def __eq__(self, other):
        return self.value == other.value

    def __lt__(self, other):
        return other.value < self.value


d = [(6, 5), (1, 3), (4, 7), (6, 4), (1, 8), (7, 9)]
e = sorted(d, key=lambda x: (x[0], Reversor(x[1])))
运行效果如下图所示:

在这里插入图片描述
并且,这个类对字符串排序依然适用:

在这里插入图片描述

总结

以上就是今天要讲的内容,本文仅仅简单介绍了python序列的使用

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

徐浪老师

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

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

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

打赏作者

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

抵扣说明:

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

余额充值