python 列表排序时,对列表元素的要求

一、引言

在上一篇博客中,我为这个探索做了准备,如果有兴趣可以查看上一篇博客,看一下准备工作中发生了什么有趣的事情。

我的目的是通过一个自定义的对象构成的列表来排序,通过报错信息不断探索排序的要求,并让自己的自定义对象最终可以进行排序。

二、探索过程

1、准备工作

我先通过一些准备工作来为我的探索做好一切需要的东西并开始我的探索,准备工作在上一个博客中已经完成。完成的代码如下:

import random

class Num:
    def __init__(self, n):
        self.n = n

    def __str__(self):
        return str(self.n)
    
    def __repr__(self):
        return str(self.n)

l = [Num(random.randint(1, 100)) for _ in range(10)]
print(l)

2、开始探索

首先直接添加一个 `l.sort()` 来尝试,不出意料肯定会报错,但是我的目的是为了查看报错信息来探索怎么解决报错,报错信息如下:

Traceback (most recent call last):
  File "C:/Users/Administrator/Desktop/temp.py", line 14, in <module>
    l.sort()
TypeError: '<' not supported between instances of 'Num' and 'Num'

可以清楚的看到,由于我的自定义对象不支持小于比较,从而无法进行排序。那我们添加这个小于号的实现方法:

def __lt__(self, target):
    return self.n < target.n

再次尝试运行,看看会有什么变化

[24, 31, 37, 40, 41, 53, 55, 59, 75, 94]

三、结论

我惊奇的发现已经做到了我想要的效果,所以我可以认为实际上只要我们能在自己自定义的对象中实现小于的实现,则我们的对象就可以拿去排序了。

通过继续的分析可以得知,当定义了 `__lt__` 方法后,会自动的完成 `__rt__` 方法,正是如此,才能完成我们整个排序的部分

说实话略微有些失望,没想到只是这么简单的道理,但是探索的过程中还是收获了一些新的知识,比如上个博客中的内容。并且探索的过程是非常有意思的。

  • 8
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

虚叶

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

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

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

打赏作者

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

抵扣说明:

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

余额充值