Python基础笔记:函数式编程:高阶函数、返回函数、匿名函数、装饰器、偏函数

高阶函数

高阶函数:一个函数可以接收另一个函数作为参数 或 一个函数可以返回一个函数作为返回值,这种函数称之为高阶函数。

#函数 add 接收 f 函数作为参数
>>> def add(x,y,f):
...     return f(x)+f(y)
...
>>> add(-5,6,abs)
11

可以把匿名函数作为返回值返回

#把匿名函数作为返回值返回
def build(x, y):
    return lambda: x * x + y * y

匿名函数

关键字 lambda 表示匿名函数,冒号前面的 x 表示函数参数

>>> list(map(lambda x:x*x,list(range(1,10))))
[1, 4, 9, 16, 25, 36, 49, 64, 81]

def f(x):
    return x*x
>>> from hello import f
>>> list(map(lambda x:x*x,list(range(1,10))))
[1, 4, 9, 16, 25, 36, 49, 64, 81]

#这两种方式等价,不过第一种代码量更少。
def f(x):
    return x*x

#等价于

lambda x:x*x

返回函数

比如我们实现一个求和函数:

def calc_sum(*args):
    ans=0
    for i in args:
        ans+=i
    return ans

但是如果不需要立刻求和,而是在后面的代码中,根据需要再计算怎么办?

可以不返回求和的结果,而是返回求和的函数:

def lazy_sum(*args):
    def sum():
        ans=0
        for i in args:
            ans+=i
        return ans
    return sum
#调用
>>> L=list(range(1,11))
>>> f=lazy_sum(*L) #返回的函数并没有立刻执行,而是直到调用了f
>>> f()
55

在这个例子中,我们在函数 lazy_sum 中又定义了函数 sum ,并且,内部函数 sum可以引用外部函数 lazy_sum 的参数和局部变量,当lazy_sum返回函数sum时,相关参数和变量都保存在返回的函数中,这种称为“闭包(Closure)”的程序结构拥有极大的威力。

当我们调用 lazy_sum() 时,每次调用都会返回一个新的函数,即使传入相同的参数:

>>> f1=lazy_sum(*L)
>>> f2=lazy_sum(*L)
>>> f1==f2
False

一个关于“闭包”的示例:

def count():
    fs=[]
    for i in range(1,4): #每次循环都创建了一个新的函数,然后把创建的3个函数都返回了
        def f():
            return i*i
        fs.append(f)
    return fs
#调用
>>> f1,f2,f3=count()
>>> f1()
9
>>> f2()
9
>>> f3()
9

怎么都是9 ?!

原因在于返回的函数引用了变量 i ,但它并非立刻执行。等到三个函数都返回时,它们所引用的变量 i 已经变成了 3,因此最终结果为9......

如果一定要引用循环变量怎么办?方法是再创建一个函数,用该函数的参数绑定循环变量当前的值,无论该循环变量后续如何更改,已绑定到函数参数的值不变:

def count():
    fs=[]
    for i in range(1,4):
        def f(i):
            def g():
                return i*i
            return g
        fs.append(f(i))
    return fs
#调用
>>> from hello import count
>>> f1,f2,f3=count()
>>> f1()
1
>>> f2()
4
>>> f3()
9

利用 lambda 函数简化:

def count():
    fs=[]
    for i in range(1,4):
        def f(i):
            return lambda :i*i
        fs.append(f(i))
    return fs

练习:利用闭包返回一个计数器函数,每次调用它返回递增整数

def count_num():
    f=[0]
    def count():
        f[0]=f[0]+1
        return f[0]
    return count
>>> from hello import count_num
>>> f=count_num()
>>> f()
1
>>> f()
2
>>> f()
3
>>>

高阶函数——map

map() 函数接收两个参数,一个是函数,一个是Iterable , map将闯入的函数一次作用到序列的每个元素,并把结果作为新的 Iterator 返回

用 map 实现把一个函数 f(x)=x*x ,作用在一个 list 上后的结果输出:

>>> L=range(1,11)
>>> L=list(range(1,11))
>>> r=map(lambda x:x*x,L)
>>> list(r)
[1, 4, 9, 16, 25, 36, 49, 64, 81, 100]

高阶函数——reduce

reduce() 函数是接受两个参数,把一个函数最用在一个序列上,reduce 把结果继续和序列的下一个元素做累积计算,其效果就是:

reduce(f, [x1, x2, x3, x4]) = f(f(f(x1, x2), x3), x4)

用reduce 实现序列求和

>>> from functools import reduce #使用reduce函数需先import
>>> L=list(range(1,11))
>>> reduce(lambda x,y:x+y,L)
55

用reduce 实现把一个整数序列变成整数

>>> L=list(range(1,10))
>>> reduce(lambda x,y:x*10+y,L)
123456789

用reduce + map 实现str 转换为 int 的函数

>>> def char_num(c):
...     digits={‘0‘:0,‘1‘:1,‘2‘:2,‘3‘:3,‘4‘:4,‘5‘:5,‘6‘:6,‘7‘:7,‘8‘:8,‘9‘:9}
...     return digits[c]
...
>>> reduce(lambda x,y :x*10+y,list(map(char_num,‘13654‘)))
13654

python 有内置的str 与int 互化的函数

>>> str(4515)
‘4515‘
>>> int(‘5252‘)
5252

练习:利用map()函数,把用户输入的不规范的英文名字,变为首字母大写,其他小写的规范名字。输入:[‘adam‘, ‘LISA‘, ‘barT‘],输出:[‘Adam‘, ‘Lisa‘, ‘Bart‘]

原文地址:https://www.cnblogs.com/jiaxinwei/p/8325598.html

时间: 2024-10-12 16:09:30

Python基础笔记:函数式编程:高阶函数、返回函数、匿名函数、装饰器、偏函数的相关文章

Python进阶:函数式编程(高阶函数,map,reduce,filter,sorted,返回函数,匿名函数,偏函数)...啊啊啊

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

Python 函数式编程--高阶函数Map、Reduce、Filter、Sorted

1.1   高阶函数 变量可指向函数 >>> abs(-10) 10 >>> x = abs    --x指向abs函数 >>> x(-1)      --直接调用x 1 调用abs和调用x完全相同. 函数名也是变量 >>> abs = 10 >>> abs(-10) Traceback (most recent call last): File "<stdin>", line 1,

函数式编程—高阶函数

一.函数式编程概念简介 函数是Python内建支持的一种封装,我们通过把大段代码拆成函数,通过一层一层的函数调用,就可以把复杂任务分解成简单的任务,这种分解可以称之为面向过程的程序设计.函数就是面向过程的程序设计的基本单元 就是越低级的语言,越贴近计算机,抽象程度低,执行效率高,比如C语言:越高级的语言,越贴近计算,抽象程度高,执行效率低,比如Lisp语言 函数式编程就是一种抽象程度很高的编程范式,纯粹的函数式编程语言编写的函数没有变量,因此,任意一个函数,只要输入是确定的,输出就是确定的,这种

python学习笔记4:高阶函数,装饰器,生成器,迭代器

一.高级函数1.把一个函数名当作实参传给另一个函数2.返回值包含函数名>>> def bar():... print ("in the bar")... >>> def foo(func):... res=func()... return res... >>> foo(bar)in the bar 二.嵌套函数在函数中定义另一个函数 三.装饰器装饰器本质上是函数,作用是装饰其他函数,就是为其他函数添加附加功能.原则1:不能修改被装饰

函数式编程--高阶函数--sorted

定义 sorted函数可以list进行排序 #sorted可以对list进行排序 L=[3,7,-11,10,6] print(sorted(L)) sorted()函数也是一个高阶函数,它还可以接收一个key函数来实现自定义的排序,key指定的函数将作用于list的每一个元素上,并根据key函数返回的结果进行排序.例如按绝对值大小排序: #接受一个abs,按照绝对值排序 print(sorted(L,key=abs)) 以上两个输出结果为: [-11, 3, 6, 7, 10] [3, 6,

python基础之函数式编程

一.函数的定义 1.定义:函数是指将一组语句的集合通过一个名字(函数名)封装起来,要想执行这个函数,只需调用其函数名即可 2.特性: (1)减少重复代码: (2)使程序变的可扩展: (3)使程序变得易维护. 3.函数的分类 (1)内置函数:为了方便我们的开发,针对一些简单的功能,python解释器已经为我们定义好了的函数即内置函数.对于内置函数,我们可以拿来就用而无需事先定义,如len(),sum(),max() (2)自定义函数:很明显内置函数所能提供的功能是有限的,这就需要我们自己根据需求,

python学习笔记---函数式编程

1. 函数本身也可以赋值给变量,即:变量可以指向函数. >>> f = abs >>> f(-10) 10 成功!说明变量f现在已经指向了abs函数本身.直接调用abs()函数和调用变量f()完全相同. --> 函数名也可以看作是是变量. 编写高阶函数,就是让函数的参数能够接收别的函数(add(-5, 6, abs)) map()函数接收两个参数,一个是函数,一个是Iterable,map将传入的函数依次作用到序列的每个元素,并把结果作为新的Iterator返回.

Python基础(30)——上下文管理,描述符,类装饰器,元类

上下文管理 with with open ('a.txt')  as f :       open(a.txt)就是实例化文件得到了一个对象,然后把对象赋值个f ,with 一个f的对象 ,后面不需要再写关闭,是因为类中间定义了一个协议,__enter__   __exit__来实现 原文地址:https://www.cnblogs.com/dayouge/p/11218698.html

函数作用域,匿名函数,map,filter,reduce---Python重新开始第五天

函数作用域 函数的作用域只跟函数声明时定义的作用域有关,跟函数的调用位置无任何关系 1 name='alex' 2 3 def foo(): 4 name='lhf' 5 def bar(): 6 name='wupeiqi' 7 print(name) 8 def tt(): 9 print(name) 10 return tt 11 return bar 12 13 # bar=foo() 14 # tt=bar() 15 # print(tt) 16 # tt() 17 r1 = foo(