Python基础12—Python函数进阶(嵌套&匿名&递归&高阶函数)(2022年)

本文详细介绍了Python中的四种高级函数用法:嵌套函数展示了函数内部的独立作用域;匿名函数lambda用于快速定义简单函数;递归函数则是函数调用自身解决问题的方法;而高阶函数则展示了函数可以接收并返回函数作为参数的特性。通过实例解析,帮助读者深入理解这些高级概念。
摘要由CSDN通过智能技术生成

系列文章目录

提示:这里可以添加系列文章的所有文章的目录,目录需要自己手动添加
例如:第一章 Python 机器学习入门之pandas的使用


提示:写完文章后,目录可以自动生成,如何生成可参考右边的帮助文档


1. 嵌套函数

每个函数里的变量是互相独立的,变量的查找顺序也是从当前层依次往上层找。了解即可

name = "Py小白雨"
def main1():
    name = "Py小白雨~~"
    def main2():
        # global name  如果声明了这句,下面的name改的是最外层的全局变层
        name = "Py小白雨~~ 雨雨雨" 
        print("第3层打印", name) 
    main2()  # 调用内层函数
    print("第2层打印", name)
main1()
print("最外层打印", name)
# 第3层打印 Py小白雨~~ 雨雨雨
# 第2层打印 Py小白雨~~
# 最外层打印 Py小白雨

2. 匿名函数

def calc(x,y):
    return x**y
print(calc(2,5))
#换成匿名函数
calc = lambda x,y:x**y
print(calc(2,5))

3. 递归函数

在函数内部,可以调用其他函数。如果一个函数在内部调用自已本身,这个函数就叫做递归函数 ,现阶段了解即可,后续会深入讲解

def calc(n):
    n = int(n/2)
    print(n)
    if n > 0:
        calc(n) #调用自己
calc(100)

递归特性:

  • 必须有一个明确的结束条件

  • 每次进入更深一层递归时,问题规模相比上次递归都应有所减少

  • 递归效率不高,递归层次过多会导致栈溢出( 函数调用是通过栈(stack)这种数据结构实现的,每当进入一个函数调用,栈就会加一层栈帧,每当函数返回,栈就会减一层栈帧。由于栈的大小不是无限的,所以,递归调用的次数过多,会导致栈溢出)

4. 高阶函数

变量可以指向函数,函数的参数能接收变量,一个函数可以接收另一个函数作为参数,称为高阶函数。

def get_abs(n):
    if n < 0 :
        n = int(str(n).strip("-"))
    return n
    
def add(x,y,f):
    return f(x) + f(y)
    
res = add(3,-6,get_abs)
print(res)
# 9
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值