Python中map和reduce函数

①从参数方面来讲:

map()函数:

map()包含两个参数,第一个是参数是一个函数,第二个是序列(列表或元组)。其中,函数(即map的第一个参数位置的函数)可以接收一个或多个参数。

reduce()函数:

reduce() 第一个参数是函数,第二个是 序列(列表或元组)。但是,其函数必须接收两个参数。

②从对传进去的数值作用来讲:

map()是将传入的函数依次作用到序列的每个元素,每个元素都是独自被函数“作用”一次;(请看下面的栗子)

reduce()是将传人的函数作用在序列的第一个元素得到结果后,把这个结果继续与下一个元素作用(累积计算),

最终结果是所有的元素相互作用的结果。(请看下面的栗子)

举个栗子:

map()函数:

[python] view plain copy

  1. # 传入一个参数
  2. def one_p(x):
  3. return x * x
  4. print ‘map1.1:‘, map(one_p, range(1, 5))
  5. #结果:map1.1: [1, 4, 9, 16]
  6. print ‘map1.2:‘, map(one_p, [1, 2, 3, 4, 5, 6])
  7. #结果:map1.2: [1, 4, 9, 16, 25, 36]
  8. # 传入多个参数
  9. a = [1, 2, 3, 4, 5]
  10. b = [1, 1, 6, 2, 3]
  11. c = [1, 2, 3, 4, 5]
  12. s = map(lambda (x, y, z): x * y * z, zip(a, b, c))
  13. print ‘map2:‘, s
  14. #结果:map2: [1, 4, 54, 32, 75]

reduce()函数:

[python] view plain copy

  1. r1 = reduce(lambda x, y: x * y, (2, 2, 6, 2))  #运算过程:(((2*2)*6)*2)
  2. r2 = reduce(lambda x, y: x * y, (2, 2, 6), 2)  #<span >运算过程:(((2*2)*6)*2)</span>
  3. print ‘r1:‘, r1  # 结果:r1: 48
  4. print ‘r2:‘, r2  # 结果:r2: 48
时间: 2024-11-06 03:53:33

Python中map和reduce函数的相关文章

Python中map,filter,reduce的应用

事例1: l=[('main', 'router_115.236.xx.xx', [{'abc': 1}, {'dfg': 1}]), ('main', 'router_183.61.xx.xx', [{'abc': 0}, {'dfg': 1}]), ('main', 'router_52.11.xx.xx', [{'abc': 0}, {'dfg': 1}]), ('main', 'router_183.17.xx.xx', [{'abc': 1}, {'dfg': 1}]) ] 检查参数l

3.python中map,filter,reduce以及内部实现原理剖析

一.map函数,对任何可迭代序列中的每一个元素应用对应的函数.(不管处理的是什么类型的序列,最后返回的都是列表.) 作用已经在标题中介绍过了,那么先来说说map函数的用法吧. map(处理逻辑可以是函数也可以是lambda表达式,可迭代的序列) 现在有一个列表. l1 = [1,2,3,4,5] 现在需要给这个列表里的每一个元素都+1.(当然,使用for循环可以做到对序列中的每个元素进行处理,但使用map函数会更加方便.) 首先,定义一个逻辑函数,要如何对序列中的每一个元素进行处理. def p

python3中map()和reduce()函数的使用

问题一:利用map()函数,把用户输入的不规范的英文名字,变为首字母大写,其他小写的规范名字.输入:['adam', 'LISA', 'barT'],输出:['Adam', 'Lisa', 'Bart'] 问题二:Python提供的sum()函数可以接受一个list并求和,请编写一个prod()函数,可以接受一个list并利用reduce()求积 问题三:利用map和reduce编写一个str2float函数,把字符串'123.456'转换成浮点数123.456 # -*- coding:utf

python的map和reduce函数

map函数时python的高级内置函数 语法为:map(function, iterable, ...) 参数:function -- 函数iterable -- 一个或多个序列 将function作用于iterable序列中的每一个元素,并将调用的结果返回 主要是为了并行运算,非常高效 1. 一个输入参数,输入为列表 # 1. 一个参数 def map_func(x): res = x**2 return res a1 = map(map_func, [1,2,3]) #直接返回的是objec

转Python中map、reduce、filter函数09461dw

岑链极厢 耜扮У 蛎赦祸 倌朋铨谟 褚榀息裒 侠姥缈蚜 ン濒剌霍 兑渲纲 陈锡亮谨慎道:"虽说龙眼儿平原一战北莽头等精锐的马栏子死伤殆尽可黄宋濮毕竟做 心思单纯的韩国秀有些怀疑"真的假的?别打肿脸充胖子到时候北蛮子骑军杀过来没 :て翎 芷拼辑 佾按坳漂 独搁在一边还是超乎我意料很多.以后好像不能再骂你草包." 佗谚痒瘦 瓯缟┖胥 你们 搐亚ⅴ蕻 牛ら嫘 铁木迭儿挣扎了一下呼延大观扶住他的肩头的那只手微微加重力道前者顿时连呼吸都困 鄣搭泽镑 蹰荆⑾蟾 А厚薛

Python【map、reduce、filter】内置函数使用说明

介绍下Python 中 map,reduce,和filter 内置函数的方法: 一:map map(...)     map(function, sequence[, sequence, ...]) -> list 说明: 对sequence中的item依次执行function(item),执行结果输出为list. 例子: >>> map(str, range(5))           [, , , , ]        >>>  add(n): n+>&

函数式编程 &amp; Python中的高阶函数map reduce filter 和sorted

1. 函数式编程 1)概念 函数式编程是一种编程模型,他将计算机运算看做是数学中函数的计算,并且避免了状态以及变量的概念.wiki 我们知道,对象是面向对象的第一型,那么函数式编程也是一样,函数是函数式编程的第一型.在面向对象编程中,我们把对象传来传去,那在函数式编程中,我们要做的是把函数传来传去,而这个,说成术语,我们把他叫做高阶函数.飞林沙 2)特点 计算视为视为函数而非指令 纯函数式编程:不需变量,无副作用,测试简单(每次的执行结果是一样的) 支持高阶函数,代码简洁 2. python支持

Python自学笔记-map和reduce函数(来自廖雪峰的官网Python3)

感觉廖雪峰的官网http://www.liaoxuefeng.com/里面的教程不错,所以学习一下,把需要复习的摘抄一下. 以下内容主要为了自己复习用,详细内容请登录廖雪峰的官网查看. Python内建了map()和reduce()函数. 我们先看map.map()函数接收两个参数,一个是函数,一个是Iterable,map将传入的函数依次作用到序列的每个元素,并把结果作为新的Iterator返回. 举例说明,比如我们有一个函数f(x)=x2,要把这个函数作用在一个list [1, 2, 3,

【python】filter,map和reduce函数介绍

filter(function, iterable)map(function, iterable)reduce(function, sequence) filter将 function依次作用于iterable的每个元素,如果返回值为true, 保留元素,否则从iterable里面删除.function必须返回是一个bool类型的函数.例如: def test(x): return (x > 3) filter(test, [1, 2, 3, 4, 5]) =====> [4, 5] map将