目录
global与nonlocal关键字
- global关键字
"""
局部名称空间直接修改全局名称空间中的数据
"""
money = 666
def index():
global money # 声明 局部名称空间中的money操作的是全局的money
money = 123
index()
print(money) # 123
- nonlocal关键字
'''
内层局部名称空间修改外层局部名称空间中的数据
'''
def index():
name = 'jason'
def inner():
nonlocal name
name = 'kevin'
inner()
print(name) # kevin
index()
函数名的多种使用方法
概念:函数名其实绑定的也是一块内存地址 只不过该地址里面存放的不是数据值而是一段代码 函数名加括号就会找到该代码并执行
1.可以当做变量名赋值(函数名与变量名使用一致)
def index():pass
res = index
res()
2.可以当做函数的参数
def index():
print('from index')
def func(a):
print(a)
a()
func(index) # from index
3.可以当做函数的返回值
def index():
print('from index')
def func():
print('from func')
return index
res = func()
print(res)
res() # from index
def index():
print('from index')
def func():
print('from func')
return func
res = index()
print(res)
res() # from func
4.可以当做容器类型(可以存放多个数据的数据类型)的数据
def index():
print('from index')
l1 = [11, 22, 11.11, 'jason', index]
l1[-1]() # from index
构造功能模板
# 定义功能编号与功能的对应关系
func_dict = {
'1':register,
'2':login,
'3':withdraw,
'4':transfer,
'5':shopping,
}
while True:
print("""
1.注册功能
2.登录功能
3.提现功能
4.转账功能
5.购物功能
""")
choice =input('>>>:').strip()
if choice in func_dict:
func_name = func_dict.get(choice)
func_name()
else:
print('结束')
# if choice == '1':
# register()
# elif choice == '2':
# login()
# elif choice == '3':
# withdraw()
# elif choice == '4':
# transfer()
# elif choice == '5':
# shopping()
# else:
# print('终于结束了')
闭包函数
"""
定义在函数内部的函数 并且用到了外部函数名称空间中的名字
1.定义在函数内容
2.用到外部函数名称空间中的名字
"""
eg:
简单的闭包函数
def index():
name = 'jason'
def inner():
print(name)
2.闭包函数的实际应用:是另外一种给函数体代码传参的方式
# 给函数体代码传参的方式1:代码里面缺什么变量名形参里面就补什么变量名
def register(name, age):
print(f"""
姓名:{name}
年龄:{age}
""")
register('jason', 18)
# 给函数体代码传参的方式2:闭包函数
def outer():
name = 'jason'
age = 18
def register():
print(f"""
姓名:{name}
年龄:{age}
""")
return register
res = outer('jason', 18)
res()
res()
装饰器简介
1.概念
在不改变被装饰对象原代码和调用方式的情况下给被装饰对象添加新的功能
2.本质
并不是一门新的技术 而是由函数参数、名称空间、函数名多种用法、闭包函数组合到一起的结果
3.口诀
对修改封闭 对扩展开放
4.储备知识
时间相关操作
import time
print(time.time()) # 时间戳(距离1970-01-01 00:00:00所经历的秒数)
time.sleep(3)
print('睡醒了')
count = 0
# 循环之前先获取时间戳
start_time = time.time()
while count < 100:
print('学习')
count += 1
end_time =time.time()
print('循环消耗的时间:', end_time - start_time)
装饰器推导流程
1。直接在调用index函数后面添加后代码
import time
def index():
time.sleep(3)
print('from index')
def home():
time.sleep(1)
print('from home')
start_time = time.time()
index()
end_time = time.time()
print('函数index的执行时间为>>>:', end_time-start_time)
2。index调用的地方较多 代码不可能反复拷贝>>>:相同的代码需要在不同的位置反复执行>>>:函数
import time
def index():
time.sleep(3)
print('from index')
def home():
time.sleep(1)
print('from home')
def get_time():
start_time = time.time()
index()
end_time = time.time()
print('函数index的执行时间为>>>:', end_time - start_time)
get_time()
3..函数体代码写死了 只能统计index的执行时间 如何才能做到统计更多的函数运行时间 直接传参变换统计的函数
import time
def index():
time.sleep(3)
print('from index')
def home():
time.sleep(1)
print('from home')
def get_time(xxx):
start_time = time.time()
xxx()
end_time = time.time()
print('函数的执行时间为>>>:', end_time - start_time)
get_time(index)
get_time(home)
4.虽然实现了一定的兼容性 但是并不符合装饰器的特征 第一种传参不写 只能考虑闭包
import time
def index():
time.sleep(3)
print('from index')
def home():
time.sleep(1)
print('from home')
def outer(xxx):
xxx = index
def get_time():
start_time = time.time()
xxx()
end_time = time.time()
print('函数的执行时间为>>>:', end_time - start_time)
return get_time
res = outer(index)
res()
res1 = outer(home)
res1()
5.调用方式还是不对 如何变形>>>:变量名赋值绑定
import time
def index():
time.sleep(3)
print('from index')
def home():
time.sleep(1)
print('from home')
def outer(xxx):
def get_time():
start_time = time.time()
xxx()
end_time = time.time()
print('函数的执行时间为>>>:', end_time - start_time)
return get_time
res = outer(index) # 赋值符号的左边是一个变量名 可以随意命名
res1 = outer(index)
res2 = outer(index)
jason = outer(index)
index = outer(index)
index()
home = outer(home)
home()
6.上述装饰器只能装饰无参函数 兼容性太差
import time
def func(a):
time.sleep(0.1)
print('from func', a)
def func1(a,b):
time.sleep(0.2)
print('from func1', a, b)
def func2():
time.sleep(0.3)
print('from func2')
func(123)
def outer(xxx):
def get_time(a, b):
start_time = time.time()
xxx(a, b)
end_time = time.time()
print('函数的执行时间为>>>:', end_time - start_time)
return get_time
func1 = outer(func1)
func1(1, 2)
func = outer(func)
func(1)
func2 = outer(func2)
func2()
7.被装饰的函数不知道有没有参数以及有几个参数 如何兼容
import time
def func(a):
time.sleep(0.1)
print('from func', a)
def func1(a,b):
time.sleep(0.2)
print('from func1', a, b)
def outer(xxx):
def get_time(*args, **kwargs): # get_time(1,2,3) args=(1,2,3)
start_time = time.time()
xxx(*args, **kwargs) # xxx(*(1,2,3)) xxx(1,2,3)
end_time = time.time()
print('函数的执行时间为>>>:', end_time - start_time)
return get_time
func = outer(func)
func(123)
func1 = outer(func1)
func1(1, 2)
8.如果被装饰的函数有返回值
import time
def func(a):
time.sleep(0.1)
print('from func', a)
return 'func'
def func1(a,b):
time.sleep(0.2)
print('from func1', a, b)
return 'func1'
def outer(xxx):
def get_time(*args, **kwargs):
start_time = time.time()
res = xxx(*args, **kwargs)
end_time = time.time()
print('函数的执行时间为>>>:', end_time - start_time)
return res
return get_time
func = outer(func)
res = func(123)
print(res)
装饰器模板
重要:
def outer(func):
def inner(*args, **kwargs):
# 执行被装饰对象之前可以做的额外操作
res = func(*args, **kwargs)
# 执行被装饰对象之后可以做的额外操作
return res
return inner
装饰语法糖
def outer(func_name):
def inner(*args, **kwargs):
print('执行被装饰对象之前可以做的额外操作')
res = func_name(*args, **kwargs)
print('执行被装饰对象之后可以做的额外操作')
return res
return inner
"""
语法糖会自动将下面挨着的函数名当做第一个参数自动传给@函数调用
"""
@outer # func = outer(func)
def func():
print('from func')
return 'func'
@outer # index = outer(index)
def index():
print('from index')
return 'index'
func()
index()
作业:
def outer(func_name):
def inner(*args, **kwargs):
'''登录程序'''
username = input('username:').strip()
password = input('password:').strip()
if username == 'jason' and password == '123':
res = func_name(*args, **kwargs)
return res
else:
print('登录失败')
return inner
@outer
def func_name(*args, **kwargs):
print('欢迎你jason,登录成功')
func_name()
user_login = False
def outer(func_name):
def inner(*args,**kwargs):
'''登录程序'''
global user_login # 将user_login变量设置成全局变量
if user_login:
ret = func_name(*args, **kwargs)
return ret
else:
username = input('username:').strip()
password = input('password:').strip()
if username == 'jason' and password == '123':
user_login = True
ret = func_name(*args, **kwargs)
return ret
else:
print('登录失败')
return inner
@outer
def func_name_1(*args, **kwargs):
print('欢迎你jason')
@outer
def func_name_2(*args, **kwargs):
print('没有验证')
func_name_1()
func_name_2()
标签:index,outer,函数,用法,func,time,print,装饰,def
From: https://www.cnblogs.com/wxlxl/p/16782785.html