py中的高级函数和Map/reduce

传入函数:
既然变量可以指向函数.函数的参数能接受变量,那么一个函数就可以接受另一个函数作为参数,这个函数就成之为高阶函数。
一个最简单的高阶函数:
def add(x,y,f):
return f(x)+f(y)
当我们调用add(-5,6,abs)时,参数x,y,和f分别接受-5,6和abs,根据函数定义,我们可以推到计算过程为:

高级函数的编写和调用。
Map/reduce
python内建立了map()和reduce()函数。
map()函数接受了俩个参数,一个是函数,一个是Iterable,map将传入的函数依次作用到序列的每个元素,并把结果作为新的Iterator返回。

map()传入的第一个参数是f,即函数对象本身。由于结果r是一个Iterator,Iterator是惰性序列,因此通过list()函数让它吧整个序列都计算出来并返回一个list。
不需要map()函数,写一个循环,也可以计算出结果:

但是,map()作为高级函数,事实上它吧运算规则抽象了,因此,我们不但可以计算简单的f(x)=x2 还可以吧任意复杂的函数,比如,吧这个list所有数字转为字符串:

接下来是reduce的用法:
reduce吧一个函数作用在一个序列[x1,x2,x3,…]上,这个函数必须接受俩个参数,reduce吧结果继续和序列的下一个元素做累计计算,其效果就是吧list中的数据全部相加:
reduce(f,[x1,x2,x3,x4])=f(f(f(x1,x2),x4))
例如:一个序列求和,就可以用reduce实现:

如果只要求和运算的话可以直接使用sum(),没必要动用reduce.
但是如果要吧序列[1,3,5,7,9]变换成整数13579,reduce就可以派上用场:

考虑到字符串str也是一个序列,对上面的列子稍微改动,配合map(),我们就可以写出吧str转换为int的函数:

整合到一块,可以用lambda函数进一步简化成:

如果说Python没有提供Int()函数,你完全可以自己写一个字符串转换为整数的函数,只需要几行代码而已!

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值