您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

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

2022/8/24 2:31:55发布49次查看
本文环境都是基于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原理图:
它通过取出序列的头两个元素,将他们传入二元函数来获得一个单一的值来实现。然后又用这个值和序列的下一个元素来获得又一个值,然后继续直到整个序列的内容都遍历完毕以及最后的值会被计算出来为止。
码字不易,多多关照
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product