filter map reduce函数的使用
#filter("处理逻辑","可迭代对象") 把可迭代对象依次处理逻辑处理,如果值为真就返回值,值为假就不返回;
li = ['testA','yerA','pp']
print(list(filter(lambda x:x.endswith('A'),li))) #['testa', 'yera']
#自己写函数实现map函数过程:
li = [1,2,3,4,5,6] #假如需要把li内容全部加1操作
def map_test(func,array):
ret = []
for i in array:
res = func(i) #func = lambda x:x+1 ; func(i)就是执行lambda函数 并把i的值传给lambda处理
ret.append(res)
return ret result = map_test(lambda x:x+1,li)
print(result) #map函数使用
# map("处理逻辑","可迭代对象") 把可迭代对象依次for循环传值给lambda处理
print(map(lambda x:x+1,li)) #<map object at 0x050A8310>生成一个可迭代对象
map_ret = list(map(lambda x:x+1,li)) #用list处理成列表
print(map_ret) #[2, 3, 4, 5, 6, 7] #map函数不是必须要用lambda函数来处理逻辑;也可以用自己定义的逻辑来处理
def add(x):
return x**2
s = list(map(add,li)) #这里面add是自己的定义的处理逻辑
print(s) #[1, 4, 9, 16, 25, 36]
#python 2 reduce可以直接用
#python 3 from functools import reduce from functools import reduce def map_reduce(x,init=None):
if init:
ret = init
else:
ret = x.pop(0)
for i in x:
ret = i + ret
return ret
li = [1,2,3,10]
s = map_reduce(li)
print(s) #reduce(function, sequence[, initial]) -> value 采用两参数累积到一序列的项的功能
#将两个参数的函数累积到序列的项上,从左到右,以便将序列减少到单个值。例如,减少(lambda x,y:x + y,[1、2、3、4、5))计算((((1 + 2)+(3)+ 4)+ 5)。
# 如果初始存在,则将其放置在计算序列的项之前,当序列为空时作为默认值。
print(reduce(lambda x,y:x+y,li)) #处理流程是把列表中的1赋值给x,把列表中的2赋值给y,第一的结果是 x = 1 + y=2,第二次计算x = 3 + y=3 依次类推
print(reduce(lambda x,y:x+y,li,10)) #处理流程是把初始值10赋值给x,把列表中的1赋值给y,第一的结果是 x = 11 + y=2,第二次计算x = 13 + y=3 依次类推
总结:
#map遍历序列中的每个元素,得到的结果是一个""列表"",列表的个数以及位置与原来的一样.
#filter遍历序列中的每个元素,判断每个元素得到的布尔值,如果是Trun就保留,不然就丢弃.
#reduce处理一个序列,然后把序列进行合并操作
filter map reduce函数的使用的更多相关文章
- Python2.7学习笔记-定义函数、filter/map/reduce/lambda
我把写的代码直接贴在下面了,注释的不是很仔细,主要是为了自己复习时方便查找,并不适合没有接触过python的人看,其实我也是初学者. #定义函数 def my_abs(x): if x>=0: ...
- Python学习(五)函数 —— 内置函数 lambda filter map reduce
Python 内置函数 lambda.filter.map.reduce Python 内置了一些比较特殊且实用的函数,使用这些能使你的代码简洁而易读. 下面对 Python 的 lambda.fil ...
- Python之匿名函数(filter,map,reduce)
参考博客:Python匿名函数详解--http://blog.csdn.net/csdnstudent/article/details/40112803 Python内建函数之——filter,map ...
- Python经常使用内置函数介绍【filter,map,reduce,apply,zip】
Python是一门非常简洁,非常优雅的语言,其非常多内置函数结合起来使用,能够使用非常少的代码来实现非常多复杂的功能,假设相同的功能要让C/C++/Java来实现的话,可能会头大,事实上Python是 ...
- 高阶函数 filter map reduce
const app=new Vue({ el:'#app', data:{ books:[{ id:1, name:"算法导论", data: '2006-1', price:39 ...
- Python内置函数之filter map reduce
Python内置函数之filter map reduce 2013-06-04 Posted by yeho Python内置了一些非常有趣.有用的函数,如:filter.map.reduce,都是对 ...
- filter,map,reduce,lambda(python3)
1.filter filter(function,sequence) 对sequence中的item依次执行function(item),将执行的结果为True(符合函数判断)的item组成一个lis ...
- lambda,filter,map,reduce
# lambda,filter,map,reduce from functools import reduce print('返回一个迭代器') print((x) for x in range(5) ...
- paip.提升效率---filter map reduce 的java 函数式编程实现
#paip.提升效率---filter map reduce 的java 函数式编程实现 ======================================================= ...
随机推荐
- 【NIO】之IO和NIO的区别
在Java1.4之前的版本,Java对I/O的支持并不完善,开发人员在开发高性能I/O程序的时候,会面临以下几个问题: 1.没有数据缓存区,I/O性能存在问题 2.没有C/C++通道的概念,输入和输出 ...
- gcc同时使用动态和静态链接
场景是这样的.我在写一个Nginx模块,该模块使用了MySQL的C客户端接口库libmysqlclient,当然mysqlclient还引用了其他的库,比如libm, libz, libcrypto等 ...
- 廖雪峰Java6 IO编程-2input和output-5操作zip
1.ZipInputStream是一种FilterInputStream 可以直接读取zip的内容 InputStream->FilterInputStream->InflateInput ...
- 安装spy-debugger查看前端日志
有时需要查看前端页面日志,但是前端同学有时忘记开启vConsole.为了调试方便,最好在本地可以查看前端日志,做到一劳永逸. 1.安装node 网上搜教程 2.安装spy-debugger sudo ...
- version control(关于版本控制)
版本控制(Version Control Systems)是一种记录一个或若干文件内容变化,以便将来查阅特定版本修订情况的系统. 这个系统可以自动帮我们备份文件的每一次更改,并且可以非常方便的恢复到 ...
- vue todolist 封装localstorage
//封装操作localstorage本地存储的方法 模块化的文件 // nodejs 基础 var storage={ set(key,value){ localStorage.setItem(key ...
- system调用导致子进程socket句柄泄漏问题分析
问题引出:A进程与B进程各自独立,都是服务器进程,常驻系统,互不相干.在某次重启A进程后,发现由于固定监听的端口被占用而无法启动.检查,发现是B进程占用了该端口,检查B进程代码,没有相关的打开该固定端 ...
- Tomcat 环境部署网站. 帆软平台部署.
主要内容. 需要使用Tomcat 部署 帆软报表平台(以下简称报表平台). 报表平台可以集成到网站, 也可独立部署. 此处是独立部署.即通过 网址:域名 独立访问这个报表平台. -- 技术要点 Tom ...
- C# 生成日期维度值
1. 时间维度表结构 /*==============================================================*/ /* Table: dim_date_day ...
- JavaWeb项目中web.xml有关servlet的基本配置
JavaWeb项目中web.xml有关servlet的基本配置: 我们注意到,tomcat下的conf中也有一个web.xml文件,没错的,所有的JavaWeb项目中web.xml都继承自服务器下的w ...