在Python3.x的世界里,cmp函数没有了。那么sorted,min,max等需要比较函数作为参数的函数该如何用呢?
以min函数的定义为例,有两种重载形式:
单参数(一个迭代器):
min(iterable[, key=func]) -> value
多参数(多个待比较内容):
min(a, b, c, ...[, key=func]) -> value
本文主要讨论key=func参数的使用 。举例说明吧:
class test:
def __init__(self,a,b):
self.a = a
self.b = b
然后实例化了三个对象x,y,z:
x=test(10,'x')
y=test(2,'y')
z=test(8,'z')
我想让它们以变量a为标准做比较,求得a最小的对象:
minTest=min(x,y,z,key=lambda t:t.a)
由于key这个参数需要传入一个函数,用lambda匿名函数很方便。本例中要实现比较函数(准确地说是比较
关键字函数),故lamda的参数只要一个,随便你取什么名字(我用的是t),代表待比较的对象(即a,b,c);冒号后面是表达式,这里直接返回t的成员变量a。
dic={'b':3,'a':5,'c':9,'d':2}
如果要根据字典的键key排序,只要:
sorted(dic)
返回一个list,是排序后的键,但是值没有放入list:
['a', 'b', 'c', 'd']
用以下方法就好了:
>>> sorted(dic.items())
[('a', 5), ('b', 3), ('c', 9), ('d', 2)]
如果要根据值value排序呢?那么就传入比较函数这一参数就好啦:
sorted(dic.items(),key=lambda d:d[1])
我继续用lambda匿名函数。其中d表示dic.items()里的每个迭代元素,即一个元组(例如('a', 5));表达式d[1]就是元组中的第二个元素(例如5),它也是字典的值value,我们需要以它为比较标准。运行结果:
[('d', 2), ('b', 3), ('a', 5), ('c', 9)]