一、引言
在上一篇博客中,我为这个探索做了准备,如果有兴趣可以查看上一篇博客,看一下准备工作中发生了什么有趣的事情。
我的目的是通过一个自定义的对象构成的列表来排序,通过报错信息不断探索排序的要求,并让自己的自定义对象最终可以进行排序。
二、探索过程
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__` 方法,正是如此,才能完成我们整个排序的部分
说实话略微有些失望,没想到只是这么简单的道理,但是探索的过程中还是收获了一些新的知识,比如上个博客中的内容。并且探索的过程是非常有意思的。