当前位置:
首页 > Python基础教程 >
-
python 之 函数(嵌套调用、名称空间与作用域、函数对象)
5.36 命名关键字
什么是命名关键字参数? 格式:在*后面参数都是命名关键字参数 特点: 1 必须被传值 2 约束函数的调用者必须按照key=value的形式传值 3 约束函数的调用者必须用我们指定的key名
def foo(x,y,*,z): print(x,y,z) foo(1,2) # z必须被传值 foo(1,2,3) # z必须以key=value的形式传值 foo(1,2,aaa=3) #必须以 z 传值 foo(1,2,z=3) # 1 2 3
5.4 函数嵌套调用
函数的嵌套调用:在函数内又调用了其他函数
def max2(x,y): if x > y: return x else: return y def max3(x,y,z): res1=max2(x,y) res2=max2(res1,z) return res2 print(max3(11,199,2))
5.5 函数名称空间与作用域
5.51 名称空间
名称空间:存放名字与值绑定关系的地方
名称空间分为三类:
1 内置名称空间:存放Python解释器自带的名字,在解释器启动时就生效,解释器关闭则失效
2、全局名称空间:文件级别的名字,在执行文件的时候生效,在文件结束或者在文件执行期间被删除则失效
x=1 def func(): name='egon' del func a = 10 def fun(): print(a) fun() print(a)
3、局部名称空间:存放函数内定义的名字(函数的参数以及函数内的名字都存放于局部名称空间),在函数调用时临时生效,函数结束则失效
def fun(): a = 10 print(a) fun() print(a) # a已经不存在了..
加载顺序:内置名称空间 ----》全局名称空间 -----》局部名称空间 查找名字:局部名称空间 ----》全局名称空间 -----》内置名称空间
5.52 作用域
全局作用域:包含的是内置名称空间与全局名称空间的名字 特点: 1、在任何位置都能够访问的到 2、该范围内的名字会伴随程序整个生命周期
局部作用域:包含的是局部名称空间的名字 特点: 1、只能在函数内使用 2、调用函数时生效,调用结束失效
5.6 函数对象
5.61 函数对象的作用
1、可以被引用
x=1 y=x def bar(): print('from bar') f=bar f()
2、func可以当作参数传给x
def bar(x): print(x) x() bar(func) def bar(): print('from bar') def wrapper(func): #func=bar func() #bar() wrapper(bar)
3、func还可以当作返回值
def bar(x): # x=func return x #return func res=bar(func) #res=func print(res) res()
4、可以当作容器类型的元素
def get(): print('from get') def put(): print('from put') l=[get,put] l[0]()
5.62 函数对象应用
利用函数作容器类型元素实现注册:
def auth(): print('登陆。。。。。') def reigster(): print('注册。。。。。') def search(): print('查看。。。。') def transfer(): print('转账。。。。') def pay(): print('支付。。。。') dic={ '1':auth, '2':reigster, '3':search, '4':transfer, '5':pay } def interactive(): while True: print(""" 1 认证 2 注册 3 查看 4 转账 5 支付 """) choice=input('>>: ').strip() if choice in dic: dic[choice]() else: print('非法操作') interactive()
5.7 闭包函数
定义在函数内部的函数, 并且该函数包含对外部函数作用域中名字的引用,该函数就称为闭包函数
闭:指的是定义在函数内部的函数 作用域关系 在函数定义阶段就规定死了,与调用位置无关
def outter(): x=2 def inner(): print(x) return inner f=outter() #f=inner f()
5.71 为函数体传值的方式
方式一:将值以参数的形式的传入
import requests def get(url): response=requests.get(url) if response.status_code == 200: print(response.text) get('https://www.baidu.com')
方式二:以闭包函数的方式调用
import requests import time def outter(url): #url='https://www.baidu.com' def get(): response=requests.get(url) if response.status_code == 200: print(response.text) return get baidu=outter('https://www.baidu.com') baidu() print('=====================>') time.sleep(3) baidu()
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式