day16_函数嵌套及对象


闭包概念:在一个内部函数中,对外部作用域的变量进行引用,(并且一般外部函数的返回值为内部函数),那么内部函数就被认为是闭包
闭包的作用;保存函数的状态信息

def
login(): print('登录功能') def transfer(): print('转账功能') def check_banlance(): print('查询余额') def withdraw(): print('提现') def register(): print('注册') func_dic = { '0': ['退出', None], '1': ['登录', login], '2': ['转账', transfer], '3': ['查询余额', check_banlance], '4': ['提现', withdraw], '5': ['注册', register] } # func_dic['1']() while True: for k in func_dic: print(k, func_dic[k][0]) choice = input('请输入命令编号:').strip() if not choice.isdigit(): print('必须输入编号,傻叉') continue if choice == '0': break # choice='1' if choice in func_dic: func_dic[choice][1]() else: print('输入的指令不存在')

函数的嵌套

# 2、函数的嵌套定义:在函数内定义其他函数
# def f1():
#     def f2():
#         pass


# 圆形
# 求圆形的求周长:2*pi*radius
def circle(radius,action=0):
    from math import pi

    def perimiter(radius):
        return 2*pi*radius

    # 求圆形的求面积:pi*(radius**2)
    def area(radius):
        return pi*(radius**2)

    if action == 0:
        return 2*pi*radius

    elif action == 1:
        return area(radius)

circle(33,action=0)

闭包函数

# 一:大前提:
# 闭包函数=名称空间与作用域+函数嵌套+函数对象
#        核心点:名字的查找关系是以函数定义阶段为准

# 二:什么是闭包函数
# "闭"函数指的该函数是内嵌函数

# "包"函数指的该函数包含对 外层函数作用域名字的引用 (不是对全局作用域) # 闭包函数:名称空间与作用域的应用+函数嵌套
# def f1(): # x = 33333333333333333333 # def f2(): # print(x) # f2() # # # x=11111 # def bar(): # x=444444 # f1() # # def foo(): # x=2222 # bar() # # foo() # 闭包函数:函数对象 # def f1(): # x = 33333333333333333333 # def f2(): # print('函数f2:',x) # return f2 # # f=f1() # # print(f) # # # x=4444 # # f() # def foo(): # x=5555 # f() # # foo() # 三:为何要有闭包函数=》闭包函数的应用 # 两种为函数体传参的方式 # 方式一:直接把函数体需要的参数定义成形参 # def f2(x): # print(x) # # f2(1) # f2(2) # f2(3) # 方式二: # def f1(x): # x=3 # x=3 # def f2(): # print(x) # return f2 # # x=f1(3) # print(x) # # x() import requests # 传参的方案一: # def get(url): # response=requests.get(url) # print(len(response.text)) # # get('https://www.baidu.com') # get('https://www.cnblogs.com/linhaifeng') # get('https://zhuanlan.zhihu.com/p/109056932') # 传参的方案二: def outter(url): # url='https://www.baidu.com' def get(): response=requests.get(url) print(len(response.text)) return get baidu=outter('https://www.baidu.com') baidu() cnblogs=outter('https://www.cnblogs.com/linhaifeng') cnblogs() zhihu=outter('https://zhuanlan.zhihu.com/p/109056932')
原文地址:https://www.cnblogs.com/pythonwork/p/15589325.html