• map函数、filer函数、reduce函数的用法和区别


    Map函数


     

    map函数的用法如下:

    def add_one(x):
        return x+1
    
    #使用普通函数
    v1 = map(add_one,[1,2,3])
    v1 = list(v1)
    print(v1)   #打印结果为[2, 3, 4]
      
    #使用匿名函数,代码更为简洁  
    v2 = map(lambda x:x+1,[1,2,3])
    v2 = list(v2)
    print(v2)   #打印结果为[2, 3, 4]

    从代码可以看出,map()函数有两个传参,第一个为函数名,第二个为可迭代对象,效果是将可迭代对象的每一个元素放入函数中执行,然后把函数执行的返回值联合一起组成一个新的可迭代对象

    filter函数


    filter函数的用法如下:

    def judge_sb(x):
        return x.startswith("sb")
    
    #使用普通函数
    v1 = filter(judge_sb,sb_list)
    v1 = list(v1)
    print(v1)  #打印结果为['sb_001', 'sb_002']
    
    #使用匿名函数,代码更为简洁
    v2 = filter(lambda x:x.startswith("sb"),sb_list)
    v2 =list(v2)
    print(v2)   #打印结果为['sb_001', 'sb_002']

    从代码可以看出,filter()函数有两个传参,第一个为函数名,第二个为可迭代对象,效果是将可迭代对象的每一个元素放入函数中执行,然后把函数执行的返回值为真,就把那个传参保留,如果为假就舍弃,最终将传参联合一起组成一个新的可迭代对象

    reduce函数


    reduce函数的用法如下:

    from functools import reduce   #要导入模块
    def add(x,y):
         return x+y
    
    #使用普通函数
    v1 = reduce(add,[1,2,5,7])
    print(v1)   #打印结果为15
    
    #使用匿名函数,代码更为简洁
    v2 = reduce(lambda x,y:x+y,[1,2,5,7])
    print(v2)   #打印结果为15

    从代码可以看出,filter()函数有两个传参,第一个为函数名,第二个为可迭代对象,效果是将可迭代对象的每一个元素进行类似累加、累乘这种压缩的操作,最后返回一个值

    总结


    #处理序列中的每个元素,得到的结果是一个可迭代对象,其元素个数及位置与原来一样

    map()

    #遍历序列中的每个元素,判断每个元素得到布尔值,如果True则留下来

    filter()

    #处理一个序列,然后把序列进行合并操作

    reduce()

  • 相关阅读:
    通俗理解乐观锁和悲观锁
    面试系列-HashMap和Hashtable的区别
    单点登录原理与实现
    CodeReview常见代码问题
    漫画:什么是冒泡排序?
    Redis 和 Memcached 的区别
    动态图文了解 8 大排序算法
    分布式系统常见的事务处理机制
    面试系列-String,StringBuffer,StringBuilder三者区别
    面试系列-高并发之synchronized
  • 原文地址:https://www.cnblogs.com/codescrew/p/8678421.html
Copyright © 2020-2023  润新知