关于 reduce 和 map
一 reduce() 函数 是python 的 模块的内容,是关于累 的 计算
在调用的时候先导入reduce模块
reduce() 接收的参数有两个,reduce(function,sequence)
reduce() 对 sequence (序列) 中的每一个元素反复调用function,并返回最终结果
from functools import reduce def func(a,b):
return a+ b
ret = reduce(func,[1,2,3,4,5])
print(ret)
ret = reduce(lambda x ,y:x+y,[1,2,3,4,5])
print(ret)
s = sum([1,2,3,4,5])
print(s)
# 结果是 15
上述计算实际上是对 list 的所有元素求和,虽然 python 内置了求和函数 sum,
但是利用 reduce()也很简单
reduce() 还可以接受第3个参数,作为计算的初始值,如果把初始值设置成100,计算:
from functools import reduce def func(a,b):
return a+ b ret = reduce(func,[1,2,3,4,5],100)
print(ret) # 结果就是 115
二 map()函数 是 python 内置的高阶函数,map(func,iter1)
它接收一个函数func 和 一个 list,并通过把函数func 依次作用在 list 的每一个元素上
得到一个新的list 并返回
例如: 对于list[1,2,3,4,5,6,7,8,9]
如果 希望把 list 的每一个元素都作 平方,就可以用函数 map()

因此,我们只需要传入 函数 f(x) = x * x ,就可以利用 map()函数完成这个计算
lst = [1,2,3,4,5,6,7,8,9] # 1.可以用函数方法实现 def func(x):
return x * x ret = list(map(func,lst))
print(ret) # 2.可以用 lambda 函数实现
ret = list(map(lambda x:x**2,lst))
print(ret) #3. for 循环也可以做到
lst_new = []
for i in lst:
lst_new.append(i *i)
print(lst_new) # 输出结果清一色的: [1, 4, 9, 16, 25, 36, 49, 64, 81]
注意: map() 函数不改变原有的list,而是返回一个新的 list
利用 map()函数,可以把一个 list 转换为 另外一个 list,只需要传入转换函数
由于 list 包含的元素可以是 任何类型,因此,map() 不仅仅可以处理只包含数值的list
事实上它可以处理包含任意类型的list,只需要传入的 func 可以处理这类数据类型
关于 reduce 和 map的更多相关文章
- 高阶函数复习:利用reduce和map把字符串转为数字
复习高阶函数的时候,有一道题想了半天解不出来.看了下别人的解法,发现学习编程,思维真的很重要. 习题: 利用map和reduce编写一个str2float函数,把字符串'123.456'转换成浮点数1 ...
- Python中Lambda, filter, reduce and map 的区别
Lambda, filter, reduce and map Lambda Operator Some like it, others hate it and many are afraid of t ...
- Python一个有意思的地方:reduce、map、filter
今天阅读了关于Python函数式编程的系列文章,地址在这里: http://www.cnblogs.com/huxi/archive/2011/06/24/2089358.html 里面提到了四个内建 ...
- python用reduce和map把字符串转为数字的方法
python用reduce和map把字符串转为数字的方法 最近在复习高阶函数的时候,有一道题想了半天解不出来.于是上午搜索资料,看了下别人的解法,发现学习编程,思维真的很重要.下面这篇文章就来给大家介 ...
- python-lambda、filter、reduce、map
python-lambda.map.filter.reduce lamdba python关键字,用于在表达式中创建匿名函数. 注意:lambda函数的定义体只能用纯表达式,不能赋值,不能使用whil ...
- 数组reduce和map方法
1.有一个长度为100的数组,请以优雅的方式求出该数组的前10个元素之和 var a = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15],sum ...
- python几个重要的函数(lambda,filter,reduce,map,zip)
一.匿名函数lambda lambda argument1,argument2,...argumentN :expression using arguments 1.lambda是一个表达式,而不是一 ...
- 内置函数,重要的四个reduce,map,lambda,filter
#filter过滤器#filter(函数,列表)#把列表里的元素序列化,然后在函数中过滤# str=["a","b","c","d ...
- reduce,map,filter 的用法
# filter用法 (对每一个数据进行筛选,满足条件的就保留)# 1,filter(功能函数,容器类型数据)# 2,过滤出来是一个地址,用list,或tuple进行包装# 3,过滤出来的是原容器类型 ...
- python的reduce,map,zip,filter和sorted函数
一. reduce(function,Iterable),它的形式和map()函数一样.不过参数function必须有两个参数. reduce()函数作用是:把结果继续和序列的下一个元素做累积计 ...
随机推荐
- 将python包发布到PyPI和制作whl文件
参考链接:wheel和egg的不同怎样将自己写的包传达到PyPi发布你自己的轮子 - PyPI打包上传实践PyPI官网上传包教程 wheel文件Wheel和Egg都是python的打包格式,目的是支持 ...
- C#操作Memcached帮助类
在VS中安装Memcached,直接在NuGet下搜索Memcached,选择第一个进行安装: 服务端资源下载地址:https://pan.baidu.com/s/1gf3tupl 接下来开始写程序, ...
- SQL查询表的第一条数据和最后一条数据
方法一: 使用TOP SELECT TOP 1 * FROM user; SELECT TOP 1 * FROM user order by id desc; 方法二: 使用LIMIT SELECT ...
- Spring boot 新建项目pom.xml文件报错 Failure to transfer org.springframework.boot:spring-boot-maven-plugin
新建项目依赖下载时网络中断导致资源损坏 删除.m2\repository中后缀名为lastUpdated的文件 cd %userprofile%\.m2\repository for /r %i in ...
- java SerialPort串口通讯的使用
api文档 http://fazecast.github.io/jSerialComm/javadoc/com/fazecast/jSerialComm/package-summary.html ma ...
- CDH6.2的spark访问oss
CDH6配置oss后:spark的配置 /opt/cloudera/parcels/CDH-6.2.0-1.cdh6.2.0.p0.967373/jars/opt/cloudera/parcels/C ...
- [CF997C]Sky Full of Stars_二项式反演_等比数列_容斥原理
Sky Full of Stars 题目链接:http://codeforces.com/problemset/problem/997/C 数据范围:略. 题解: 首先考虑拟对象,如果至少有一行完全相 ...
- Vue.directive()的用法和实例
官网实例: https://cn.vuejs.org/v2/api/#Vue-directive https://cn.vuejs.org/v2/guide/custom-directive.html ...
- java类和对象详解
类和对象 java 是面向对象的语言 即 万物皆对象c语言是面向过程语言 一.怎么去描述一个对象? (1)..静态的(短时间内不会改变的东西) 例如:外观,颜色,品牌 (2).动态的(动作) 可以干什 ...
- Netty源码剖析-业务处理
参考文献:极客时间傅健老师的<Netty源码剖析与实战>Talk is cheap.show me the code! ----主线:worker thread 触发pipeline.fi ...