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函数就是将具 ...
随机推荐
- SpringMVC中前端Form表单提交后跳转不过去的问题
今天晚上打算谢谢Spring整合这个内容,写的差不多之后运行 出现了各种问题 逐一排查 首先有一个(MyEclipse10) 一: class path resource [spring-mvc.xm ...
- Resharper 2020 免费破解版
如果你是一名.NET开发人员,但是你却不使用ReSharper,那么你就不是一个合格的码农了,因为这是一个强大的神器,你值得拥有!当然,用它的代价是,启动VS会变得非常慢,非常卡,但是需要知道,磨刀不 ...
- tars 问题汇总
1. 节点 ip地址变了如何解决.后台不可以改. 2. [ok] 服务如何在本地运行../HelloGo --config.conf
- package_ios
PlistBuddy简单使用 https://www.jianshu.com/p/2167f755c47e xcodebuild 命令 https://www.jianshu.com/p/c32263 ...
- docker run <image-id>和 docker start <container-id>
- Vue企业级优雅实战03-准备工作04-全局设置
本文包括如下几个部分: 初始化环境变量文件 JS 配置文件初始化:如是否开启 Mock 数据.加载本地菜单.URL 请求路径等: 国际化文件初始化:初始化国际化文件的结构: 整合 Element UI ...
- 剑指 Offer 46. 把数字翻译成字符串
题目描述 给定一个数字,我们按照如下规则把它翻译为字符串:0 翻译成 "a" ,1 翻译成 "b",--,11 翻译成 "l",--,25 ...
- 使用代码生成工具快速生成基于ABP框架的Vue+Element的前端界面
世界上唯一不变的东西就是变化,我们通过总结变化的规律,以规律来应付变化,一切事情处理起来事半功倍.我们在开发后端服务代码,前端界面代码的时候,界面都是依照一定的规律进行变化的,我们通过抽取数据库信息, ...
- C#中TextBox设置readonly不能读取数据问题
在ASP.NET中前端设置控件TextBox的属性为Readonly="True"时,如果之前有设定初始值,或通过JS方式给其赋值后,在后台访问其Text值却无法获取,这种问题的解 ...
- 设计模式也可以这么简单(7年开发老鸟PS注释总结)
设计模式是对大家实际工作中写的各种代码进行高层次抽象的总结,其中最出名的当属 Gang of Four (GoF) 的分类了,他们将设计模式分类为 23 种经典的模式,根据用途我们又可以分为三大类,分 ...