把函数作为参数传入,这样的函数称为高阶函数,函数式编程就是指这种高度抽象的编程范式。
1.map函数
map() 会根据提供的函数对指定序列做映射。
第一个参数接受一个函数名,后面的参数接受一个或多个可迭代的序列,返回的是一个集合。
实例:
##实例一:
def multi(x):
return x*5
result=map(multi,[1,2,3,4,5])
print(list(result))
##运行结果##
[1,10,15,20,25]
##实例二:
result=map(lambda x,y:x+y,[1,2,3,4],[5,6,7,8])
print(list(result))
##运行结果##
[6,8,10,12]
注意: map无法处理seq长度不一致、对应位置操作数类型不一致的情况
2.reduce函数
reduce() 函数会对参数序列中元素进行累积。
第一个参数接受一个函数名,后面的参数接受一个或多个可迭代的序列,返回的是一个结果。
reduce()函数接收的参数和 map()类似,一个函数 f,一个list,但行为和 map()不同,reduce()传入的函数 f 必须接收两个参数,reduce()对list的每个元素反复调用函数f,并返回最终结果值。
实例:
def sum(x,y):
return x+y
reduce(sum,[1,2,3,4,5])
##运行结果##
15
调用reduce(sum,[1,2,3,4,5])时,依次把列表[1,2,3,4,5]中的元素加起来。
reduce()还可以接收第3个可选参数,作为计算的初始值。
reduce(sum,[1,2,3,4,5],10)
##运行结果将变为##
25
3.filter() 函数
用于过滤序列,过滤掉不符合条件的元素,返回由符合条件元素组成的新列表。
第一个参数接受一个函数名,后面的参数接受一个或多个可迭代的序列,序列的每个元素作为参数传递给函数进行判断,返回True或False,将返回True的元素放到新列表中。
实例:
##过滤列表中所有的偶数
def iseven(n):
return n%2==0
newlist = list(filter(iseven, [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]))
print(newlist)
##运行结果##
[2,4,6,8,10]