python3 sorted 如何实现自定义排序标准

作者:ke1th 时间:2022-09-19 21:32:49 

在 python2 中,如果想要自定义评价标准的话,可以这么做


def cmp(a, b):
# 如果逻辑上认为 a < b ,返回 -1
# 如果逻辑上认为 a > b , 返回 1
# 如果逻辑上认为 a == b, 返回 0
pass

a = [2,3,1,2]
a = sorted(a, cmp)

但是在 python3 中,cmp 这个参数已经被移除了,那么在 python3 中应该怎么实现 python2 的 cmp 功能呢?


import functools
def cmp(a, b):
 if b < a:
   return -1
 if a < b:
   return 1
 return 0
a = [1, 2, 5, 4]
print(sorted(a, key=functools.cmp_to_key(cmp)))

上面这个方法实现了降序排列,因为 -1 代表我们逻辑上认为 a<b ,而实际上 b<a 。

追溯 cmp_to_key 的源码,发现是这样的


def cmp_to_key(mycmp):
 """Convert a cmp= function into a key= function"""
 class K(object):
   __slots__ = ['obj']
   def __init__(self, obj):
     self.obj = obj
   def __lt__(self, other):
     return mycmp(self.obj, other.obj) < 0
   def __gt__(self, other):
     return mycmp(self.obj, other.obj) > 0
   def __eq__(self, other):
     return mycmp(self.obj, other.obj) == 0
   def __le__(self, other):
     return mycmp(self.obj, other.obj) <= 0
   def __ge__(self, other):
     return mycmp(self.obj, other.obj) >= 0
   __hash__ = None
 return K

返回的是一个类,在 sorted 内部,类接收一个参数构造一个实例,然后实例通过重载的方法来进行比较。


k1 = K(1)
k2 = K(2)

# 问题,k1,k2 谁是 self,谁是 other
# k1 是 self, k2 是 other
print(k1 < k2)

补充知识:Python sorted--key参数用法

sorted(iterable[, key][, reverse])

从 iterable 中的项目返回新的排序列表。

有两个可选参数,必须指定为关键字参数。

key 指定一个参数的函数,用于从每个列表元素中提取比较键:key=str.lower。默认值为 None (直接比较元素)。

reverse 是一个布尔值。如果设置为 True,那么列表元素将按照每个比较反转进行排序。

示例:创建由元组构成的列表:a = [('b',3), ('a',2), ('d',4), ('c',1)]

按照第一个元素排序

sorted(a, key=lambda x:x[0])

>>> [('a',2),('b',3),('c',1),('d',4)]

按照第二个元素排序

sorted(a, key=lambda x:x[1])

>>> [('c',1),('a',2),('b',3),('d',4)]

key = lambda x:x[?] 是固定写法,x其实可以为任意值。

来源:https://blog.csdn.net/u012436149/article/details/79952975

标签:python3,sorted,自定义,排序
0
投稿

猜你喜欢

  • Go语言题解LeetCode561数组拆分

    2023-06-20 22:49:14
  • Tensorflow实现神经网络拟合线性回归

    2022-10-09 06:24:49
  • JavaScript延时效果比较不错的

    2024-04-22 13:22:48
  • PHP求最大子序列和的算法实现

    2023-11-15 04:17:28
  • 利用Python的Django框架中的ORM建立查询API

    2023-11-15 10:06:03
  • Spring Batch读取txt文件并写入数据库的方法教程

    2024-01-27 03:59:32
  • python中安装Scrapy模块依赖包汇总

    2023-11-08 07:06:25
  • Go调度器学习之goroutine调度详解

    2024-04-30 10:06:10
  • 免费开源百度编辑器(UEditor)使用方法

    2023-06-01 18:05:08
  • 10款顶级jQuery插件推荐

    2011-08-14 07:55:39
  • pandas 使用均值填充缺失值列的小技巧分享

    2023-01-21 02:29:25
  • Python入门:认识列表和元组

    2022-11-06 02:18:42
  • 利用Python实现简单的Excel统计函数

    2021-09-27 09:21:09
  • php替换字符串中间字符为省略号的方法

    2023-09-30 20:16:04
  • ES6记录异步函数的执行时间详解

    2024-04-10 16:18:56
  • javascript+css3开发打气球小游戏完整代码

    2024-05-02 16:15:54
  • SQL Server 性能调优之查询从20秒至2秒的处理方法

    2024-01-24 14:01:56
  • Python读取环境变量的方法和自定义类分享

    2022-11-13 23:47:08
  • numpy ndarray 按条件筛选数组,关联筛选的例子

    2021-04-12 04:58:09
  • ORACLE查询删除重复记录三种方法

    2024-01-19 11:03:10
  • asp之家 网络编程 m.aspxhome.com