今天在做一个对字典的value排序并获取对应key操作的时候,看到一个非常简洁的方法,在这里记录一下。
文章目录min和max方法
key参数
实例演示
扩展
min和max方法
常规情况下,只需要传递一个iterable对象即可
In [2]: a=[4,23,65,3,12]
In [3]: min(a)
Out[3]: 3
In [4]: max(a)
Out[4]: 65
当然,传递多个单值也是没有问题的
In [5]: min(3,45,2,33,56)
Out[5]: 2
In [6]: max(3,45,2,33,56)
Out[6]: 56
但是如果查看这俩方法的docstring会发现其除了这种基本使用还可以传递别的参数
In [1]: max?
Docstring:
max(iterable, *[, default=obj, key=func]) -> value
max(arg1, arg2, *args, *[, key=func]) -> value
With a single iterable argument, return its biggest item. The
default keyword-only argument specifies an object to return if
the provided iterable is empty.
With two or more arguments, return the largest argument.
Type: builtin_function_or_method
default是默认值比较好理解,下面我们就来重点看看这个key参数怎么玩的。
key参数
key参数需要传递一个函数名,在进行比较前首先用这个函数对前面用来比较的每个元素进行一次预处理。
在不经过任何处理的情况下,下面的list最大值是按照字符串的第一个字符来排列,如果相等再按照第二个字符继续比较,所以得到的是第一个字符最大的4做为最大值
In [7]: max('1','111','2','33','4')
Out[7]: '4'
但是我们希望的是按照数值的大小来进行排序而不是字符串的比较规则,于是定义一个函数将所有传递的值变成int
In [8]: def toInt(value):
...: return int(value)
...:
然后将这个函数赋值给key去对所有的元素进行预处理转变为int再比较
In [9]: max('1','111','2','33','4',key=toInt)
Out[9]: '111'
成功得到数值最大的结果,并且注意,按照预处理后的结果进行比较,但是返回的还是是未经过处理的内容!
当然,没有人会这么蠢专门去定义一个函数赋值,直接用lambda函数弄个匿名函数搞定即可
In [10]: max('1','111','2','33','4',key=lambda x:int(x))
Out[10]: '111'
结果是一样的。
实例演示
下面来说回我遇到的问题,对字典找出value最大值对应的key。
这时候就比较好处理了,只需要将(key,value)对传到max方法中,再对key传递一个函数从键值对提取得到value即可。
获取键值对的方法如下
dic.items()
首先有一个字典如下
In [11]: dic={'a':33,'b':2,'c':87,'d':56,'e':9}
再用dic.items()来试试
In [14]: max(dic.items(),key=lambda x:x[1])
Out[14]: ('c', 87)
没有问题。
扩展
有了这个key参数去进行预处理,一下子min和max函数变得厉害了起来。
不光可以求最值,还可以在排序的时候同样使用
In [17]: sorted(dic.items(),key=lambda x:x[1])
Out[17]: [('b', 2), ('e', 9), ('a', 33), ('d', 56), ('c', 87)]
注意sort是直接对原list进行操作,而sorted是生成一个新的list。
我是T型人小付,一位坚持终身学习的互联网从业者。喜欢我的博客欢迎在csdn上关注我,如果有问题欢迎在底下的评论区交流,谢谢。