关于 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()函数作用是:把结果继续和序列的下一个元素做累积计 ...
随机推荐
- hibernate 第二次深入接触
1.session 到底如何进行脏处理? 当一个Dept对象加入到session缓存时,Session会为Dept对象的值属性复制一份快照,当Session刷新缓存时,会进行脏处理. 2.OID 用来 ...
- CentOS 7安装gevent
CentOS 7安装gevent 首先确认python版本不低于python 2.7 执行python –V(或者python -vision) 安装pip工具 方式一: [root@server-0 ...
- 使用canal通过mysql复制协议从binlog实现热数据nosql缓存(2)
开启mysql binlog功能 以5.7版本为例,找到/etc/mysql/mysql.conf.d/mysqld.cnf [mysqld] pid-file = /var/run/mysqld/m ...
- 深入理解java虚拟机---读书笔记
第一章 走近java 1. java 技术体系: java 程序设计语言 各种硬件平台上的java虚拟机 class 文件格式 java API 类库 来自商业机构或者开源机构的第三方java类库 j ...
- 【AtCoder】AGC003
AGC编号越小越水???? AGC003 A - Wanna go back home 相对方向要么一起有要么一起没有 #include <bits/stdc++.h> #define f ...
- 剑指offer47:位运算+递归。求1+2+3+...+n,要求不能使用乘除法、for、while、if、else、switch、case等关键字及条件判断语句(A?B:C)。
1 题目描述 求1+2+3+...+n,要求不能使用乘除法.for.while.if.else.switch.case等关键字及条件判断语句(A?B:C). 2 思路和方法 (1)递归,不能使用if等 ...
- LRU算法简介
LRU是什么? 按照英文的直接原义就是Least Recently Used,最近最久未使用法,它是按照一个非常注明的计算机操作系统基础理论得来的:最近使用的页面数据会在未来一段时期内仍然被使用,已经 ...
- Timezone offset does not match system offset: 0 != -32400. Please, check your config files
apscheduler使用uWSGI的mule模块部署的时候报错, 因为系统时区和代码运行时区不一样导致. 解决办法:在初始化的时候指定上海的时区 scheduler = BlockingSchedu ...
- Pygame小游戏练习三
@Python编程从入门到实践 Python项目练习 七.创建Passenger类 创建passenger.py文件,创建Passenger类,控制乘客属性和行为 # passenger.py imp ...
- Spring实战(二)Spring容器和bean的生命周期
引入问题: 在XML配置文件中配置bean后,这些文件又是如何被加载的?它们被加载到哪里去了? Spring容器——框架核心 1.什么是Spring容器?它的功能是什么? 在基于Spring的应用中, ...