欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

python reduce/map/filter函数区别

程序员文章站 2022-07-06 11:17:02
python 中 reduce / map / filter 三个函数很容易搞混淆,虽然利用函数对迭代器或者序列中的元素操作,但是适用的场景却各不相同; 一.map函数 map函数特点:对可迭代器或者序列中的每个元素进行相同的操作(例如每个元素+1等等),并返回迭代器或者列表,示例如下: # !us ......

 

 

    python 中  /  /  三个函数很容易搞混淆,虽然利用函数对迭代器或者序列中的元素操作,但是适用的场景却各不相同;

一.map函数

    map函数特点:对可迭代器或者序列中的每个元素进行相同的操作(例如每个元素+1等等),并返回迭代器或者列表,示例如下:

   输出结果:

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函数返回的迭代器只能迭代一次,解决办法:在获取结果的时候强转为即可,实例如下:

输出:

[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的解决方案一样,在获取结果的时候强转为即可;

 

 

猜你喜欢:

    1.python线程互斥锁lock

    2.python进程互斥锁lock

    3.python gil锁

    4.python gil锁与互斥锁lock的区别

 

    转载请注明:猿说python »

 

技术交流、商务合作请直接联系博主
扫码或搜索:猿说python
python reduce/map/filter函数区别
猿说python
微信公众号 扫一扫关注