map reduce lambda 区别 用法 结合使用
来源:互联网 发布:52mac网可靠吗 编辑:程序博客网 时间:2024/06/05 03:21
1. map
map()函数接收两个参数,一个是函数,一个是Iterable,map将传入的函数依次作用到序列的每个元素,并把结果作为新的Iterator返回
例子1
#把list里面每个元素的平方计算出来def f(n): return n*nprint map(f,[1,2,3,4,5,6,7,8,9])
#输出[1, 4, 9, 16, 25, 36, 49, 64, 81]
例子2
#把这个list所有数字转为字符串list = [1,2,3,4,5,6,7,8,9]print map(str,list )
#输出['1', '2', '3', '4', '5', '6', '7', '8', '9']
2. reduce
上面说了map将传入的函数依次作用到序列的每个元素,但是reduce不一样,reduce把前一个元素的计算结果和下一个元素做累计计算,reduce的函数需要接受两个参数,就像这样
reduce(f,[x1,x2,x3,x4])=f(f(f(x1,x2),x3),x4)
例子1
#对一个序列求和from functools import reducedef f(x,y): return x+yprint reduce(f,[1,2,3,4])#输出10,其实也可以用sum([1,2,3,4])
例子2
#把序列[1, 3, 5, 7, 9]变换成整数13579from functools import reducedef f(x,y): return x*10+yprint reduce(f,[1,2,3,4])#输出1234
例子3
map和reduce结合使用
字符串str也是一个序列,把字符串’13579’转换为int类型的13579
from functools import reducedef fn(x,y): return x*10+ydef convertstrtoint(s): return {'0': 0, '1': 1, '2': 2, '3': 3, '4': 4, '5': 5, '6': 6, '7': 7, '8': 8, '9': 9}[s]print reduce(fn,map(convertstrtoint,'13579'))
3. lambda
lambda x: x * x
冒号前面的x表示函数参数,后面的是表达式
匿名函数有个限制,就是只能有一个表达式,不用写return,返回值就是该表达式的结果。
用匿名函数有个好处,因为函数没有名字,不必担心函数名冲突。此外,匿名函数也是一个函数对象,也可以把匿名函数赋值给一个变量,再利用变量来调用该函数:
上面的例子用lambda匿名函数改编一下,结合使用效果如下
from functools import reducedef convertstrtoint(s): return {'0': 0, '1': 1, '2': 2, '3': 3, '4': 4, '5': 5, '6': 6, '7': 7, '8': 8, '9': 9}[s]print reduce(lambda x,y:x*10+y,map(convertstrtoint,'13579'))
阅读全文
0 0
- map reduce lambda 区别 用法 结合使用
- lambda表达式,结合map、reduce、filter函数
- python特殊用法:filter map reduce lambda
- python: lambda, filter, map, reduce 用法
- Python3 zip,lambda,map,reduce的使用
- filter、map、reduce、lambda
- lambda(),map(),reduce(),filter()
- filter、map、reduce、lambda
- Python中 filter | map | reduce | lambda的用法
- python中的map/reduce, filter, lambda, set的用法
- Python中filter、map、reduce、lambda 的用法
- [Python]中filter、map、reduce、lambda的用法
- Python中reduce与lambda的结合使用
- Python中filter、lambda、map、reduce的使用
- python filter lambda reduce map
- Python: lambda, map, reduce, filter
- Python filter、map、reduce、lambda
- Python:lambda、map、filter、reduce
- (已解决)雷柏v500在Ubuntu系统下键位映射错误
- 【cas】sso和cas概述
- 常见的动态规划问题分析与求解
- 个人随笔和笔记:响应式布局meta声明
- iOS时间戳
- map reduce lambda 区别 用法 结合使用
- C++资源
- 浅析逆元&逆元的蛋用(完全版)
- centos下通过终端查找存储指令的文件名
- 测试小白应该会的MySQL操作
- Linux下Rsync+Inotify-tools实现数据实时同步
- 聚合数据手机验证码在ThinkPHP中实现
- 响应式布局个人随笔
- 对向量的处理,在控制板显示出按钮42