python reduce/map/filter函数区别
程序员文章站
2022-05-04 14:59:41
python 中 reduce / map / filter 三个函数很容易搞混淆,虽然利用函数对迭代器或者序列中的元素操作,但是适用的场景却各不相同; 一.map函数 map函数特点:对可迭代器或者序列中的每个元素进行相同的操作(例如每个元素+1等等),并返回迭代器或者列表,示例如下: # !us ......
python 中 / / 三个函数很容易搞混淆,虽然利用函数对迭代器或者序列中的元素操作,但是适用的场景却各不相同;
一.map函数
map函数特点:对可迭代器或者序列中的每个元素进行相同的操作(例如每个元素+1等等),并返回迭代器或者列表,示例如下:
# !usr/bin/env python # -*- coding:utf-8 _*- """ @author:何以解忧 @blog(个人博客地址): shuopython.com @wechat official account(微信公众号):猿说python @github:www.github.com @file:python_reduce_list_map.py @time:2020/3/6 10:25 @motto:不积跬步无以至千里,不积小流无以成江海,程序人生的精彩需要坚持不懈地积累! """ def func1(x): # 将每一个元素计算平方值 print("x=%d x*x=%d"%(x,x*x)) return x*x if __name__ == "__main__": list1 = [1,2,3,4,5] #方法一: value = map(func1,list1) #返回map对象,可以强制转为list列表 print(list(value)) print("***"*20) #方法二: value = map(lambda x:x*x, list1) #返回map对象,可以强制转为list列表 print(list(value))
输出结果:
x=1 x*x=1 x=2 x*x=4 x=3 x*x=9 x=4 x*x=16 x=5 x*x=25 [1, 4, 9, 16, 25] ************************************************************ [1, 4, 9, 16, 25]
值得注意的是:map函数返回值是迭代器,注意返回的结果只能迭代一次,如果需要多次使用请提前保存结果并处理,例如:
def func1(x): # 将每一个元素计算平方值 # print("x=%d x*x=%d"%(x,x*x)) return x*x if __name__ == "__main__": list1 = [1,2,3,4,5] value = map(func1,list1) #返回map对象,可以强制转为list列表 print(list(value)) print(list(value))
输出结果:
[1, 4, 9, 16, 25] []
很懵逼是不是?明明没什么错误,为什么第二次输出就是空列表呢?因为map函数返回的迭代器只能迭代一次,解决办法:在获取结果的时候强转为即可,实例如下:
def func1(x): # 将每一个元素计算平方值 # print("x=%d x*x=%d"%(x,x*x)) return x*x if __name__ == "__main__": list1 = [1,2,3,4,5] value = list(map(func1,list1)) #返回map对象,可以强制转为list列表 print(list(value)) print(list(value))
输出:
[1, 4, 9, 16, 25] [1, 4, 9, 16, 25]
二.reduce函数
reduce函数特点:从左到右对一个序列的项累计地应用有两个参数的函数,以此合并序列到一个单一值(例如累加或累乘列表元素等等),返回最终的计算结果,是一个值,示例如下:
#python3在使用reduce函数时需要导入模块 from functools import reduce # 导入模块 def func1(x,y): # 把上一次计算的结果作为下一次的计算的输入 print("x=%d y=%d x*y=%d"%(x,y,x*y)) return x*y if __name__ == "__main__": list1 = [1,2,3,4,5] #方法一: value = reduce(func1,list1) #等价 1*2*3*4*5 = 120 print(value) print(type(value)) print("***"*20) #方法二: value = reduce(lambda x,y:x*y, list1) # 等价 1*2*3*4*5 = 120 print(value) print(type(value))
输出结果:
x=1 y=2 x*y=2 x=2 y=3 x*y=6 x=6 y=4 x*y=24 x=24 y=5 x*y=120 120 <class 'int'> ************************************************************ 120 <class 'int'>
三.filter函数
filter函数特点:对可迭代对象中的元素按照特定的条件进行筛选(例如筛选列表中所有的偶数等等),示例如下:
lis=[0,1,2,3,4,5,6] #定义筛选偶数的普通函数 def func4(x): return x%2==0 #第一种使用filter函数的方式---lambda res5=filter(lambda x:x%2==0,lis) print(list(res5)) print(list(res5)) print("***"*20) #第二种使用filter函数的方式---普通函数二 res7=filter(func4,lis) print(list(res7)) print(list(res7))
输出结果:
[0, 2, 4, 6] [] ************************************************************ [0, 2, 4, 6] []
懵逼?事实证明,filter函数返回的结果也和map函数一样,只能迭代一次,解决方案和map的解决方案一样,在获取结果的时候强转为即可;
猜你喜欢:
转载请注明:猿说python »
技术交流、商务合作请直接联系博主
扫码或搜索:猿说python
猿说python
微信公众号 扫一扫关注
上一篇: 爬虫报错(持续.....)
下一篇: PHP实现的单向散列加密操作示例
推荐阅读
-
JavaScript数组迭代方法:forEach(),map(),filter(),reduce(),every(),some(),indexOf(),lastIndexOf(),find()
-
js 数组方法 forEach map includes filter some every find findIndex reduce
-
分享jquery中map函数与each函数两者区别
-
python 2 map() reduce()函数用法讲解
-
python用reduce和map把字符串转为数字的方法
-
Python中map,reduce,filter和sorted函数的使用方法
-
python并行化介绍ThreadPool对象map函数的使用
-
ES6数组新特性解析(map,filter,forEach,reduce)
-
Python中map,reduce,filter和sorted函数的使用方法
-
python中的reduce内建函数使用方法指南