Python中sort、sorted的cmp参数废弃之后使用__lt__支持复杂比较的方法

时间:2022-04-17 19:34:24

Python2.1以前的排序比较方法只提供一个cmp比较函数参数,没有__lt__等6个富比较方法, Python 2.1引入了富比较方法,Python3.4之后作废了cmp参数。相应地从Python2.4开始,list.sort方法 和 sorted方法 都增加了一个 ‘key’ 参数用来在进行比较之前指定每个列表元素上要调用的函数。但是这个函数不能支持两个对象之间进行比较,只支持对某个对象处理后返回一个值。那么要实现复杂的排序比较方法怎么处理呢?其实Python有多种处理方法,老猿在此介绍使用__lt__支持复杂比较的方法。

老猿在《第8.23节 Python中使用sort/sorted排序与“富比较”方法的关系分析》《Python中自定义类未定义__lt__方法使用sort/sorted排序会怎么处理?》中介绍了排序方法sort和函数sorted在没有提供key参数的情况下默认调用__lt__或__gt__方法来进行排序比较,因此如果要实现复杂类的实例对象的排序,只要将原cmp参数对应函数的功能稍微调整后移植到自定义类中的__lt__方法或__gt__方法实现就可以支持复杂比较的方法。

关于重写富比较方法请参考:

《第8.22节 Python案例详解:重写 “富比较”方法控制比较逻辑》

老猿Python,跟老猿学Python!

博客地址:https://blog.csdn.net/LaoYuanPython


请大家多多支持,点赞、评论和加关注!谢谢!