首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Python入门基础之map、reduce函数使用

本文环境都是基于python3.X的,毕竟要学会拥抱未来,拥抱新的知识。Python3 现在已经发展的差不多了。

1、 map()函数

简介

map()是 python 内置的高阶函数,它接收一个函数 f 和一个 list,并通过把函数 f 依次作用在 list 的每个元素上,得到一个新的object并返回。(python2返回列表,Python3返回迭代对象)

map()的使用方法形如map(f(x),Itera),它有两个参数,第一个参数为某个函数,第二个为可迭代对象。

基本用法:

注意:python3中map()返回的是一个object,因为map()转变成了迭代器来节约空间,返回的是可迭代对象

如果需要list可以直接用list(……)来强制返回一个列表。

Map的主要作用就是:并行!并行!并行!map函数和zip函数都是用来进行并行运算,迭代等。

在多进程编程中,Pool池的用法中一种就是利用map函数开启多进程,可以大大提高程序的效率。

Map原理:

在最简单的形式中,map()带一个函数和队列,将函数作用在序列的每个元素上,然后创建由每次函数应用组成的返回值列表。如下图所示:

调用函数运行:

2、reduce()函数

简介

reduce()的使用方法形如reduce(function, iterable[, initializer]),它的形式和map()函数一样。不过参数f(x)必须有两个参数,initializer是可选的。

reduce 使用了一个二元函数(一个接收带带两个值作为输入,进行了一些计算然后返回一个值作为输出),一个序列,和一个可选的初始化器,卓有成效地将那个列表的内容"减少"为一个单一的值,如同它的名字一样。

请看实例:(注意在Python3中reduce不再是内置函数,而是集成到了functools中,需要导入)

它返回的结果相当于(1+2+3+4+5)

Reduce原理:

它通过取出序列的头两个元素,将他们传入二元函数来获得一个单一的值来实现。然后又用这个值和序列的下一个元素来获得又一个值,然后继续直到整个序列的内容都遍历完毕以及最后的值会被计算出来为止。

码字不易,多多关照

  • 发表于:
  • 原文链接http://kuaibao.qq.com/s/20180311A0K9P700?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券