我们专注攀枝花网站设计 攀枝花网站制作 攀枝花网站建设
成都网站建设公司服务热线:400-028-6601

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

如何分析python的map、reduce函数

这篇文章给大家介绍如何分析python的map、reduce函数,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

在庆安等地区,都构建了全面的区域性战略布局,加强发展的系统性、市场前瞻性、产品创新能力,以专注、极致的服务理念,为客户提供成都网站设计、网站制作、外贸营销网站建设 网站设计制作按需网站制作,公司网站建设,企业网站建设,成都品牌网站建设,营销型网站,外贸网站建设,庆安网站建设费用合理。

小编讲的是Python的map、reduce两大函数。

这对兄弟是出现频率极高相当实用的python函数,初学者会较难理解,看完本文你就能搞定它们喽!

如何分析python的map、reduce函数

01

map

map()方法会将 一个函数 映射序列的每一个元素上,生成新序列,包含所有函数返回值。

也就是说序列里每一个元素都被当做x变量,放到一个函数f(x)里,其结果是f(x1)、f(x2)、f(x3)......组成的新序列。

如何分析python的map、reduce函数

如何使用map函数?

     
   
   
   map(function_to_apply, list_of_inputs)
  • function_to_apply:代表函数

  • list_of_inputs:代表输入序列

注意:python3中 map函数返回的是 迭代器  

大多数时候,我们要把列表中所有元素一个个地传递给一个函数,并收集输出。

比方说:

     
   
   
   items = [1, 2, 3, 4, 5] # 列表  
    
    squared = []  
    
    for i in items:  
    
        squared.append(i**2)

map函数可以让我们用一种简单而漂亮得多的方式来实现:

     
   
   
   items = [1, 2, 3, 4, 5]  
    
    squared = list(map(lambda x: x**2, items))

上面使用了匿名函数,也可以自定义函数:

     
   
   
   items = [1, 2, 3, 4, 5]  
    
    def f(x):  
    
        return x**2  
    
    squared = list(map(f, items))

02

reduce

reduce相比map稍复杂点

reduce的工作过程是 :在迭代序列的过程中,首先把 前两个元素(只能两个)传给 函数,函数加工后,然后把 得到的结果和第三个元素 作为两个参数传给函数参数, 函数加工后得到的结果又和第四个元素 作为两个参数传给函数参数,依次类推。 

如何分析python的map、reduce函数

reduce函数怎么用?

     
   
   
   reduce(function, iterable[, initializer])
  • function:代表函数

  • iterable:序列

  • initializer:初始值(可选)

与map不同,reduce不可以直接使用,需要用from functools import reduce导入

如何分析python的map、reduce函数

比如说我要求10的阶乘,就可以用reduce做:

     
   
   
   # 导入reduce  
    
    from functools import reduce   
    
    # 定义函数  
    
    def f(x,y):  
    
        return x*y  
    
    # 定义序列,含1~10的元素  
    
    items = range(1,11)  
    
    # 使用reduce方法  
    
    result = reduce(f,items)  
    
    print(result)

关于如何分析python的map、reduce函数就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。


分享题目:如何分析python的map、reduce函数
文章路径:http://mswzjz.cn/article/gihois.html

其他资讯