接受两个参数,一个是函数变量,一个是List,map()会把函数变量作用于List中的每个元素,最后返回一个新的List。
接受两个参数,一个是函数变量,一个是List;与map()的区别在于,reduce中的函数变量必须接受两个参数,而reduce则会把这个函数依次作用于前面的处理结果和下一个元素。
例如,编写一个f函数,接收x和y,返回x和y的和:
def f(x, y):
return x + y
调用 reduce(f, [1, 3, 5, 7, 9])时,reduce函数将做如下计算:
先计算头两个元素:f(1, 3),结果为4;
再把结果和第3个元素计算:f(4, 5),结果为9;
再把结果和第4个元素计算:f(9, 7),结果为16;
再把结果和第5个元素计算:f(16, 9),结果为25;
由于没有更多的元素了,计算结束,返回结果25。
reduce()还可以接收第3个可选参数,作为计算的初始值。
接受两个参数,一个是函数变量,一个是List;filter()会通过函数判断List中的每一个值,对于函数返回值为true的情况,filter()会把此时的List元素筛选出来,重新组成一个新的List。
sort()可以为List排序,不管List中的元素是数字还是字符串;也可以实现倒序排序,那么需要自己定义倒序排序函数,然后把这个倒序函数作为参数传进去。