Python-函数式编程-map reduce filter lambda 三元表达式 闭包
lambda
匿名函数,核心是作为算子,处理逻辑只有一行但具有函数的特性,核心用于函数式编程中
三元运算符
其实本质上是if分支的简化版,满足条件返回 if 前面的值,不满足条件返回 else后面的值
# 100 < 100 返回 False, 则 返回 else后面的值
value = 100 if 100 < 100 else 10
print(value)
map
映射函数(依次把可迭代对象(可多个)中的值依次传递到函数中,然后返回生成器(长度以最短的为基础))
numbers = [1, 2, 3, 4]
names = ['bei_men_chui_xue', 'qi_niu_yun'] numbers = map(lambda value: value + 1, numbers)
students = map(lambda value: value.upper(), names) print(list(numbers))
print(list(students))
reduce
减少函数(连续计算,处理函数中第一个值是上一次函数执行的返回结果,第二个值是依次从迭代对象中的值,传递完则返回最后函数执行的结果)
from random import randint
from functools import reduce numbers = [randint(-10, 10) for _ in range(10)]
print(numbers)
print(sum(numbers))
numbers_sum = reduce(lambda one, two: one + two, numbers)
print(numbers_sum)
filter
依次依顺序把可迭代对象传入一个函数,获取函数返回为True的值,变成生成器
from random import randint numbers = [randint(-10, 10) for _ in range(10)]
print(numbers) # 取大于等于0 的整数
result = filter(lambda value: value >= 0, numbers)
print(list(result))
闭包
函数 + 环境变量(放在上层函数, 上层函数没有任何参数,则不能形成闭包) (不再受外层函数之外的任何参数影响)
闭包架构 函数内再定义一个函数,外层函数返回内层函数名,内层函数需要引用外层函数变量
闭包意义:函数调用的现场(上层函数的变量)保存了起来, 通过 nonlocal 声明不是当前函数局部变量,进行现场变量的修改
闭包是装饰器实现的原理,所有的闭包问题都可以通过面向对象类的方式解决,选择简单实现的额方法
def is_jpg(name):
"""判断文件的后缀名是是不是jpg,如果不是则添加上jpg"""
def wrapper(filename):
if filename.endswith(name):
return filename
else:
return filename + name
return wrapper if __name__ == '__main__':
f = is_jpg('.jpg')
print(f('beimenchuixue.txt'))
print(f('beimenchuixue.jpg'))
经验:
1. 三元运算符其实本质上是if分支的简写逻辑
2. 经常使用的是命令是编程,命令式编程包含流程控制、函数、分支、循环,函数式编程包括map reduce filter lambda,理论上可以替换所有命令式编程
3. 命令式编程可以使用函数式编程简化代码逻辑
4. 函数闭包,本质上保留了上层函数的变量
Python-函数式编程-map reduce filter lambda 三元表达式 闭包的更多相关文章
- Python函数式编程-map/reduce
1.map map()传入的第一个参数是f,即函数对象本身. map()函数接收两个参数,一个是函数,一个是Interable,map将传入的函数依次作用到序列的每个元素,并把结果作为新的Iterat ...
- Python函数式编程——map()、reduce()
文章来源:http://www.pythoner.com/46.html 提起map和reduce想必大家并不陌生,Google公司2003年提出了一个名为MapReduce的编程模型[1],用于处理 ...
- (转)Python函数式编程——map()、reduce()
转自:http://www.jianshu.com/p/7fe3408e6048 1.map(func,seq1[,seq2...]) Python 函数式编程中的map()函数是将func作用于se ...
- map/reduce/filter/lambda
Python内建了map()/reduce()/filter()函数. map()函数接收两个参数,一个是函数,一个是Iterable,map将传入的函数依次作用到序列的每个元素,并把结果作为新的It ...
- Python的函数式编程: map, reduce, sorted, filter, lambda
Python的函数式编程 摘录: Python对函数式编程提供部分支持.由于Python允许使用变量,因此,Python不是纯函数式编程语言. 函数是Python内建支持的一种封装,我们通过把大段代码 ...
- python 中的map(), reduce(), filter
据说是函数式编程的一个函数(然后也有人tucao py不太适合干这个),在我看来算是pythonic的一种写法. 简化了我们的操作,比方我们想将list中的数字都加1,最基本的可能是编写一个函数: I ...
- 1.python函数式编程-map函数
编程方法论 面向过程 函数式 面向对象 面向过程 将编程过程拆分成多个步骤,在函数中按照每个步骤进行编程: 函数式编程 编程语言定义的函数+数学意义的函数 1.不可变,不用变量保存状态,不修改变量: ...
- 函数式编程Map()&Reduce()
.forEach():每个元素都调用指定函数,可传三个参数:数组元素丶元素索引丶数组本身丶 , , , , , , , ]; a.forEach(function(v,i,a){a[i]=v+;}); ...
- python基础之map/reduce/filter/sorted
---map(fun,iterable) 首先来看一看map()函数,map函数接受两个参数,第一个参数是函数的名称,第二个参数一个可迭代对象.即map(fun,iterable) map函数就是将具 ...
随机推荐
- 图数据库对比:Neo4j vs Nebula Graph vs HugeGraph
本文系腾讯云安全团队李航宇.邓昶博撰写 图数据库在挖掘黑灰团伙以及建立安全知识图谱等安全领域有着天然的优势.为了能更好的服务业务,选择一款高效并且贴合业务发展的图数据库就变得尤为关键.本文挑选了几款业 ...
- oracle再回首
第一章 Oracle 数据库的使用 一. 数据库相关概念 1 什么是数据库 所谓的数据库其实就是数据的集合.用户可以对集合中的数据进行新增.查询.更新. 删除等操作.数据库是以一定方式储存在一 ...
- 外贸网站SEO优化哪家公司好
http://www.wocaoseo.com/thread-98-1-1.html 随着b2c的崛起,越来越多的企业已经放弃挂在第三方面台销售,而是选择去建独立的商场,拥有一个属于自已 ...
- Blazor带我重玩前端(五)
概述 本文主要讨论Blazor事件内容,由于blazor事件部分很多,所以会分成上下两篇,本文为第一篇,后续会有第二篇. 我们可以视组件是一个类,我们先看一下前文所说的Index.Razor页面生成的 ...
- Docker 网络模式详解及容器间网络通信
当项目大规模使用 Docker 时,容器通信的问题也就产生了.要解决容器通信问题,必须先了解很多关于网络的知识.Docker 作为目前最火的轻量级容器技术,有很多令人称道的功能,如 Docker 的镜 ...
- Collection/Map关系图
- three.js尝试(一)模拟演唱会效果
工作闲暇之余,偶然翻到了Three.js的官网,立刻被它酷炫的案例给惊艳到了,当即下定决心要试验摸索一番,于是看demo,尝试,踩坑,解决问题,终于搞定了,一个模拟演唱会场景. 主角围绕一个钢管在舞动 ...
- OpenResty 作者章亦春访谈实录
[软件简介] OpenResty (也称为 ngx_openresty)是一个全功能的 Web 应用服务器.它打包了标准的 Nginx 核心,很多的常用的第三方模块,以及它们的大多数依赖项. 通过众多 ...
- 小程序开发-组件navigator导航篇
navigator 页面链接 navigator的open-type属性 可选值 navigate.redirect.switchTab,对应于wx.navigateTo.wx.redirectTo. ...
- 万字长文,以代码的思想去详细讲解yolov3算法的实现原理和训练过程,Visdrone数据集实战训练
以代码的思想去详细讲解yolov3算法的实现原理和训练过程,并教使用visdrone2019数据集和自己制作数据集两种方式去训练自己的pytorch搭建的yolov3模型,吐血整理万字长文,纯属干货 ...