python之函数式编程与函数闭包

防伪码:忘情公子著

Python函数式编程:

函数式编程:

也称作泛函编程,是一种编程范型,说白了就是实现可以把函数当参数传递给另一个函数;

它将电脑运算视为数学上的函数计算,并且避免状态以及可变数据;

函数式编程语言最重要的基础是lambda演算,而且lambda演算的函数可以接受函数当作输入和输出

Python支持有限的函数式编程功能:

filter(func,seq):

调用一个布尔函数func来迭代遍历每个seq中的元素;返回一个使func返回值为true的元素的序列

In [1]: def a(x):
   ...:     if x > 20:
   ...:         return True
   ...:     else:
   ...:         return False
   ...: 

In [2]: l1 = [1,2,3,4,20,21,25,40,50,32,47]

In [3]: filter(a,l1)
Out[3]: [21, 25, 40, 50, 32, 47]

filter()是一个过滤器:

filter()为已知的序列的每个元素调用给定的布尔函数;

调用中,返回值为非零值的元素将被添加至一个列表中

map(func,seq1[,seq2...]):

将函数func作用于给定序列(s)的每个元素,并用一个列表来提供返回值;

如果func为None,func表现为一个身份函数,返回一个含有每个序列中元素集合的n个元组的列表

In [1]: l1 = [0,1,2,3,4,5,6]

In [2]: l2 = [‘Sun‘,‘Mon‘,‘Tue‘,‘Wed‘,‘Thu‘,‘Fri‘,‘Sat‘]

In [3]: map(None,l1,l2)
Out[3]:
[(0, ‘Sun‘),
 (1, ‘Mon‘),
 (2, ‘Tue‘),
 (3, ‘Wed‘),
 (4, ‘Thu‘),
 (5, ‘Fri‘),
 (6, ‘Sat‘)]
In [4]: l1 = [0,1,2,3,4,5,6]

In [5]: l2 = [‘Sun‘,‘Mon‘,‘Tue‘,‘Wed‘,‘Thu‘,‘Fri‘,‘Sat‘]

In [6]: def a(x,y):            #这里的函数参数个数要与map函数中序列的个数一致
   ...:     return x*2,y*2
   ...:

In [7]: map(a,l1,l2)
Out[7]:
[(0, ‘SunSun‘),
 (2, ‘MonMon‘),
 (4, ‘TueTue‘),
 (6, ‘WedWed‘),
 (8, ‘ThuThu‘),
 (10, ‘FriFri‘),
 (12, ‘SatSat‘)]

map()是一个映射器;

map()将函数调用“映射”到每个序列的对应元素上并返回一个含有所有返回值的列表。说白点也就是它能将不同序列的同一个位置上的元素通过func函数处理后整合成一个元组,最后生成一个元组列表

带有单个队列的map()如下图所示:

带有多个队列的map()如下图所示:

reduce(func,seq[,init]):

将二元函数作用于seq序列的元素,每次携带一对(先前的结果以及下一个序列元素),连续地将现有的结果和下一个值作用在获得的随后的结果上,最后减少我们的序列为一个单一的返回值;如果初始值init给定,第一个比较会是init和第一个序列元素而不是序列的头两个元素

说白点reduce就是实现折叠功能

In [9]: l1 = [0,1,2,3,4,5,6]

In [10]: def a(x,y):
    ...:     return x + y
    ...:

In [11]: reduce(a,l1)        #返回所有参数之和
Out[11]: 21

In [12]: reduce(a,l1,10)     #返回所有参数+初始值之和
Out[12]: 31

Python函数闭包:

闭包叫lexical closure(词法闭包)。是指函数及相关的环境组成的整体。

闭包指的就是一个内层函数和所处的环境(外层函数)所构成的内容所组成的整体。

闭包只是在形式和表现上像函数,但事实上闭包自身并不是函数。

闭包从其表现的形式上可以解释为函数在嵌套环境中,如果在一个内层函数里对外层函数作用域中的变量进行了引用,那么在外层函数返回后,内层函数依然可以使用其外层函数中被引用的变量,这种变量就构成了内层函数可以使用的环境。

In [1]: def func1(x):            #外层函数
   ...:     def func2(y):        #内层函数
   ...:         return y ** x
   ...:     return func2
   ...:

In [2]: f4 = func1(4)

In [3]: type(f4)
Out[3]: function

In [4]: f4(2)
Out[4]: 16

In [5]: f4(3)
Out[5]: 81
In [6]: def startPos(m,n):        #象棋起始位置
   ...:     def newPos(x,y):      #象棋新位置
   ...:         return "The old position is (%d,%d),and the new position is (%d,%d)."% (m,n,m+x,n+y)
   ...:     return newPos
   ...:

In [7]: action = startPos(10,10)

In [8]: action(1,2)
Out[8]: ‘The old position is (10,10),and the new position is (11,12).‘

In [9]: action = startPos(11,12)

In [10]: action(3,-2)
Out[10]: ‘The old position is (11,12),and the new position is (14,10).‘

对于外层函数中的变量施加了修改,内层函数也就相应的受到影响,所以说外层函数给内层函数提供了一个运行环境,这就叫做闭包。

时间: 2024-10-01 01:14:31

python之函数式编程与函数闭包的相关文章

Python的函数式编程-传入函数、排序算法、函数作为返回值、匿名函数、偏函数、装饰器

函数是Python内建支持的一种封装,我们通过把大段代码拆成函数,通过一层一层的函数调用,就可以把复杂任务分解成简单的任务,这种分解可以称之为面向过程的程序设计.函数就是面向过程的程序设计的基本单元. 传入函数 函数的本身也可以作为参数. Python内建的mapreduce的函数.(来源于谷歌的,后来被道格这家伙开源了,成为当今处理大数据最火热的hadoop中的计算模型---MapReduce) 我们先看map.map()函数接收两个参数,一个是函数,一个是序列,map将传入的函数依次作用到序

Python进阶之函数式编程(把函数作为参数)

什么是函数式编程? 什么是函数式编程? 函数:function 函数式:functional,一种编程范式 函数式编程是一种抽象计算的编程模式 函数≠函数式,比如:计算≠计算机 在计算机当中,计算机硬件是最底层的,而越往上语言越高级 低--------------------------------->高计算机硬件-->汇编语言-->c语言-->Python语言 ↓ ↓ ↓ 指令 函数 函数式计算机------------------------>计算(数学) ○ 函数式编程

学习日志---python(函数式编程)

函数式编程 后面的闭包和装饰器很重要,参数可以是函数,把函数传进去参与运算. 过程是一个没有返回值的函数,函数本身也是一个对象,因此可以赋值给引用: 一个模块中函数不可重名,因此不支持重载,因为python是以函数名来识别调用的哪一个: 模块中函数的定义是自上而下的: 可以多个返回值,看作是一个元组:也可以分开多个变量接受返回值: def p():     return 1,2,3 a=p() print a a,b,c=p() print a,b,c 函数的属性 文档属性:__doc__ 可以

Python进阶-函数式编程

花了一个多小时学习python的函数式编程,终于算入门了,这接近一万字的教程,原作者分了十几课,我融合在一起方便查阅. 函数式编程 functional,是编程的一种范式 特点有: 把计算视为函数而不是指令 纯函数式编程不需要变量,没有副作用,测试简单 支持高阶函数,代码简洁 Python支持函数式编程: python不是纯函数式语言,允许有变量 支持高阶函数,函数也可作为变量传入 支持闭包,有了闭包就能返回函数 有限度地支持匿名函数 高阶函数是什么 先了解以下概念: 1.变量可以指向一个函数,

python 入门 - 函数式编程

函数式编程的一个特点就是,允许把函数本身作为参数传入另一个函数,还允许返回一个函数 http://www.liaoxuefeng.com/wiki/001374738125095c955c1e6d8bb493182103fac9270762a000/001386819196283586a37629844456ca7e5a7faa9b94ee8000     函数 定义函数 def my_abs(x): if x >= 0: return x else: return -x result =my_

python之函数式编程

函数是Python内建支持的一种封装,我们通过把大段代码拆成函数,通过一层一层的函数调用,就可以把复杂任务分解成简单的任务,这种分解可以称之为面向过程的程 序设计.函数就是面向过程的程序设计的基本单元. 而函数式编程(请注意多了一个“式”字)——Functional Programming,虽然也可以归结到面向过程的程序设计,但其思想更接近数学计算. 我们首先要搞明白计算机(Computer)和计算(Compute)的概念. 在计算机的层次上,CPU执行的是加减乘除的指令代码,以及各种条件判断和

python 之函数式编程

函数是Python内建支持的一种封装,我们通过把大段代码拆成函数,通过一层一层的函数调用,就可以把复杂任务分解成简单的任务,这种分解可以称之为面向过程的程序设计.函数就是面向过程的程序设计的基本单元. 而函数式编程(请注意多了一个"式"字)--Functional Programming,虽然也可以归结到面向过程的程序设计,但其思想更接近数学计算. 我们首先要搞明白计算机(Computer)和计算(Compute)的概念. 在计算机的层次上,CPU执行的是加减乘除的指令代码,以及各种条

Python的函数式编程,从入门到?放弃?

转:http://python.jobbole.com/84927/ 很早以前就听说过了函数式编程,印象中是一种很晦涩难懂的编程模式,但却一直没有去进行了解. 恰好这周组内的周会轮到我主持,一时也没想到要分享什么.灵光一闪,就选定函数式编程这个主题吧,反正组里的同事都没有学过,只需要讲解入门方面的知识就好,也正好可以借这个机会逼迫自己去学习下这种新的编程方式. 经过初步了解,发现支持函数式编程的语言挺多的,除了像Lisp.Scheme.Haskell.Erlang这样专用的函数式编程语言,我们常

python基础-函数式编程

python基础-函数式编程  高阶函数:map , reduce ,filter,sorted 匿名函数:  lambda  1.1函数式编程 面向过程编程:我们通过把大段代码拆成函数,通过一层一层的函数,可以把复杂的任务分解成简单的任务,这种一步一步的分解可以称之为面向过程的程序设计.函数就是面向过程的程序设计的基本单元. 函数式编程:是使用一系列函数去解决问题,函数式编程就是根据编程的范式来,得出想要的结果,只要是输入时确定的,输出就是确定的. 1.2高阶函数 能把函数作为参数传入,这样的