reduce、map、filter 互相转化

Python有一个有意思的事情,就是reduce、map和filter,三者可以相互转换。例如以reduce为基础,可以实现map和filter函数如下:


1 def _map(func, iterable):

2     return reduce(lambda lst, x: lst.append(func(x)) or lst, iterable, [])

3 

4 def _filter(func, iterable):

5     return reduce(lambda lst, x: lst.append(x) or lst if func(x) else lst, iterable, [])



上面的or操作符是用作流程控制的, lst.append(x) or lst 会将x添加到lst中去, 然后返回lst,因为lst.append(x)会返回None。


基于map或filter去实现其他的函数也是可以的,只不过它们都不像基于reduce实现的map和filter那样简洁。贴出实现如下:


这个是基于map去实现reduce和filter:


#map as the base

def _reduce(func, iterable, init):
    result = init
    map(lambda x: result = func(result, x), iterable)
    return result

def _filter(func, iterable):
    lst= []
    map(lambda x: lst.append(x) if func(x), iterable)
    return lst


这个是基于filter去实现另外两者:


#filter as the base

def _reduce(func, iterable, init):
    result = init
    filter(lambda x: result = func(result, x), iterable)
    return result

def _map(func, iterable):
    lst = []
    filter(lambda x: lst.append(func(x)), iterable)
    return lst


可以发现它们大同小异,不过很有意思。


转载地址: http://www.cnblogs.com/starstone/p/4809768.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值