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. 函数闭包,本质上保留了上层函数的变量

  

原文地址:https://www.cnblogs.com/2bjiujiu/p/9141077.html

时间: 2024-08-08 01:25:29

Python-函数式编程-map reduce filter lambda 三元表达式 闭包的相关文章

Python函数式编程 map reduce filter

函数式编程,使代码简洁高效. Map函数: map(func, *iterables),作用是将一个列表映射到另一个列表. class map(object): """ map(func, *iterables) --> map object Make an iterator that computes the function using arguments from each of the iterables. Stops when the shortest ite

Python函数式编程-map/reduce

1.map map()传入的第一个参数是f,即函数对象本身. map()函数接收两个参数,一个是函数,一个是Interable,map将传入的函数依次作用到序列的每个元素,并把结果作为新的Iterator返回. >>> def f(x): ... return x*x ... >>> r=map(f,[1,2,3,4,5]) >>> list (r) [1, 4, 9, 16, 25] 2.reduce reduce把一个函数作用在一个序列[x1, x

Python函数式编程——map()、reduce()

文章来源:http://www.pythoner.com/46.html 提起map和reduce想必大家并不陌生,Google公司2003年提出了一个名为MapReduce的编程模型[1],用于处理大规模海量数据,并在之后广泛的应用于Google的各项应用中,2006年Apache的Hadoop项目[2]正式将MapReduce纳入到项目中. 好吧,闲话少说,今天要介绍的是Python函数式编程中的另外两个内建函数map()和reduce(),而不是Google的MapReduce. 1.ma

(转)Python函数式编程——map()、reduce()

转自:http://www.jianshu.com/p/7fe3408e6048 1.map(func,seq1[,seq2...]) Python 函数式编程中的map()函数是将func作用于seq中的每一个元素,并用一个列表给出返回值.如果func为None,作用通zip().当seq只有一个时,将func函数作用于这个seq的每一个元素上,得到一个新的seq. 举个例子来说明,(假设我们想要得到一个列表中数字%3的余数,那么可以写成下面的代码): >>> print map(la

1.python函数式编程-map函数

编程方法论 面向过程 函数式 面向对象 面向过程 将编程过程拆分成多个步骤,在函数中按照每个步骤进行编程: 函数式编程 编程语言定义的函数+数学意义的函数 1.不可变,不用变量保存状态,不修改变量: 2.第一类对象,函数即变量---------高阶函数:把函数当做参数传递给另外一个函数:返回值中包含函数.(装饰器) 3.尾调用:在函数的最后一步调用另外一个函数(最后一行不一定是函数的最后一步) 调用栈:在系统调用递归函数的时候不是最后一步(区别最后一行),则需要保留当前层的状态.如果是最后一步进

python基础之map/reduce/filter/sorted

---map() 首先来看一看map()函数,map函数接受两个参数,第一个参数是算法,第二个参数是具体数值(注意,数值必须为可迭代的).即map(fun,iterable) map函数就是将具体数值根据算法进行计算,并将结果保存为一个迭代器.我们知道,迭代器很'懒',通过调用next函数一次只输出一个值. 来看一个最简单的map()例子. #给定一组数1,2,3,4,5,6.要求求出每个数加一后的值 def fun(x): x=x+1 return x li=[1,2,3,4,5,6] r=m

Python函数式编程——filter()、map()、reduce()

提起map和reduce想必大家并不陌生,Google公司2003年提出了一个名为MapReduce的编程模型[1],用于处理大规模海量数据,并在之后广泛的应用于Google的各项应用中,2006年Apache的Hadoop项目[2]正式将MapReduce纳入到项目中. 好吧,闲话少说,今天要介绍的是Python函数式编程中的另外两个内建函数map()和reduce(),而不是Google的MapReduce. 1.filter() 格式:filter( func, seq ) 该内建函数的作

python--函数式编程 (高阶函数(map , reduce ,filter,sorted),匿名函数(lambda))

1.1函数式编程 面向过程编程:我们通过把大段代码拆成函数,通过一层一层的函数,可以把复杂的任务分解成简单的任务,这种一步一步的分解可以称之为面向过程的程序设计.函数就是面向过程的程序设计的基本单元. 函数式编程:是使用一系列函数去解决问题,函数式编程就是根据编程的范式来的出想要的结果,只要是输入时确定的,输出就是确定的. 1.2高阶函数 能把函数作为参数传入,这样的函数就称为高阶函数. 1.2.1函数即变量 以python的内置函数print()为列,调用该函数一下代码 >>> pri

函数式编程工具:filter和reduce

# -*- coding: utf-8 -*- #python 27 #xiaodeng #函数式编程工具:filter和reduce #python内置函数中,map函数是用来进行函数式编程这类工具最简单的内置函数代数 #函数式编程含义: #一种编程范式,也就是如何编写程序的方法论,是一种编程思想. #无法给予准确的定义 #函数式编程的编程风格强调表达式计算,而不是执行命令. #常见函数式编程 #filter:基于某一测试函数过滤出一些元素 #reduce:对每对元素都应用函数并运行到最后结果