自学Python4.3-装饰器固定格式
自学Python之路-Python基础+模块+面向对象
自学Python之路-Python网络编程自学Python之路-Python并发编程+数据库+前端自学Python之路-django
自学Python4.3-装饰器固定格式
1.装饰有返回值的装饰器
import time
print(time.time()) def timmer(f): #装饰器函数
def inner():
start = time.time()
ret = f() #被装饰的函数
end = time.time()
print(end - start)
return ret
return inner @timmer #语法糖 @装饰器函数名
def func(): #被装饰的函数
time.sleep(0.01)
print('我好喜欢大家啊~')
return '新年好'
# func = timmer(func)
ret = func() #inner()
print(ret)
以上代码:
执行timmer(func), 返回inner (此时此刻func就是inner) 执行func的时候就是执行inner, 所以在inner里面加个返回值
2. 装饰带参数函数的装饰器
2.1 如果被装饰函数有参数, 有一个参数:
import time
print(time.time()) def timmer(f): #装饰器函数
def inner(a):
start = time.time()
ret = f(a) #被装饰的函数
end = time.time()
print(end - start)
return ret
return inner @timmer #语法糖 @装饰器函数名
def func(a): #被装饰的函数
time.sleep(0.01)
print('我好喜欢大家啊',a)
return '新年好'
# func = timmer(func)
ret = func(1) #inner()
print(ret)

2.2 如果被装饰函数有参数, 有2个参数:
import time
print(time.time()) def timmer(f): #装饰器函数
def inner(a,b):
start = time.time()
ret = f(a,b) #被装饰的函数
end = time.time()
print(end - start)
return ret
return inner @timmer #语法糖 @装饰器函数名
def func(a,b): #被装饰的函数
time.sleep(0.01)
print('我好喜欢大家啊',a,b)
return '新年好'
# func = timmer(func)
ret = func(2598,2417) #inner()
print(ret)

2.3 如果被装饰函数有2个,一个函数有1个参数, 另一个函数有2个参数:
import time
print(time.time()) def timmer(f): #装饰器函数
def inner(*args):
start = time.time()
ret = f(*args) #被装饰的函数
end = time.time()
print(end - start)
return ret
return inner @timmer #语法糖 @装饰器函数名
def func1(a): #被装饰的函数func1
time.sleep(0.01)
print('我好喜欢大家啊',a)
return '新年好'
# func = timmer(func)
def func2(a,b): #被装饰的函数func2
time.sleep(0.01)
print('我爱大家啊',a,b)
return '过年好'
# func = timmer(func)
ret = func1(48785) #inner()
ret = func2(2598,2417) #inner()
print(ret)

以上只解决了按位置传参数, 但是如果按关键字传参数就会有问题。于是, 可传万能参数
import time
print(time.time()) def timmer(f): #装饰器函数
def inner(*args,**kwargs):
start = time.time()
ret = f(*args,**kwargs) #被装饰的函数
end = time.time()
print(end - start)
return ret
return inner @timmer #语法糖 @装饰器函数名
def func1(a): #被装饰的函数func1
time.sleep(0.01)
print('我好喜欢大家啊',a)
return '新年好'
# func = timmer(func)
def func2(a,b): #被装饰的函数func2
time.sleep(0.01)
print('我爱大家啊',a,b)
return '过年好'
# func = timmer(func)
ret = func1(48785) #inner()
ret = func2(2598,b=2) #inner()
print(ret)

3. 引出---装饰器的固定格式
def wrapper(f): #装饰器函数,f是被装饰的函数
def inner(*args,**kwargs):
'''在被装饰函数之前要做的事'''
ret = f(*args,**kwargs) #被装饰的函数
'''在被装饰函数之后要做的事'''
return ret
return inner
@wrapper #语法糖 @装饰器函数名
def func(a,b): #被装饰的函数
time.sleep(0.01)
print('我好喜欢大家',a,b)
return '新年好'
ret = func()
注意点:
- func 是被装饰的函数
- 调用所有被装饰的函数,其实就是调用的inner
单独打印*args,会将参数打散,输出每一个参数。(接收是聚合,调用是打散)


所以以下的例子,inner(*args) 相当于inner(1,2,3,4)

举例代码:
def wrapper(func):
def inner(*args,**kwargs):
print('在被装饰的函数执行之前做的事')
ret = func(*args,**kwargs)
print('在被装饰的函数执行之后做的事')
return ret
return inner @wrapper #holiday = wrapper(holiday)
def holiday(day):
print('全体放假%s天'%day)
return '好开心' ret = holiday(3)
print(ret)

- 1. 执行def wrapper(func) ,放到内存
- 2. 执行holiday=wrapper(holiday)的右部分,传给wrapper下面代码
- 3. 执行def inner(*args,**kwargs)
- 4. return inner 返回地址
- 5. 返回地址给holiday , 赋值
- 6. 执行ret=holiday(3)右部分, 就是相当于inner(3)
- 7. 执行inner函数,print('在被装饰的函数执行之前做的事')
- 8. ret = func(*args,**kwargs) 相当于holiday(*(3),**{})
- 9. 执行函数holiday(3),print('全体放假%s天'%day)
- 10. return “好开心”
- 11. 返回值给ret = func(*args,**kwargs) 的左部分
- 12. print('在被装饰的函数执行之后做的事')
- 13. return ret ,拿到返回值“好开心”
- 14.返回值给holiday=wrapper(holiday)的左部分
- 15.print(ret)
...
自学Python4.3-装饰器固定格式的更多相关文章
- 自学Python4.4-装饰器的进阶
自学Python之路-Python基础+模块+面向对象自学Python之路-Python网络编程自学Python之路-Python并发编程+数据库+前端自学Python之路-django 自学Pyth ...
- 自学Python4.5-装饰器举例
自学Python之路-Python基础+模块+面向对象自学Python之路-Python网络编程自学Python之路-Python并发编程+数据库+前端自学Python之路-django 自学Pyth ...
- 自学Python4.2-装饰器
自学Python之路-Python基础+模块+面向对象自学Python之路-Python网络编程自学Python之路-Python并发编程+数据库+前端自学Python之路-django 自学Pyth ...
- 自学Python4.6-迭代器
自学Python之路-Python基础+模块+面向对象自学Python之路-Python网络编程自学Python之路-Python并发编程+数据库+前端自学Python之路-django 自学Pyth ...
- python--4、装饰器
装饰器(Decorator) 使用场景:为被装饰器装饰的函数增加功能,但又不希望修改函数的定义,即在代码运行期间动态增加功能. 装饰器更多的用于后期功能升级而不是编写新的代码.装饰器不光能装饰函数,也 ...
- day11(python)装饰器
def wrapper(f):#1 def inner(*args,**kwargs):#3 ret = f(*args,**kwargs)#5 return ret#8 return inner#4 ...
- python基础-5.2装饰器
1.了解装饰器前准备 #### 第一波 #### def foo(): print 'foo' foo #表示是函数,仅指向了函数的地址,为执行 foo() #表示执行foo函数 #### 第二波 # ...
- python之装饰器函数
本章内容 引入 装饰器的形成过程 开放封闭原则 谈装饰器主要功能和装饰器固定结构 带参数的装饰器 多个装饰器装饰一个函数 引入 作为一个会写函数的python开发,我们从今天开始要去公司上班了.写了一 ...
- python之路——装饰器函数
阅读目录 楔子 装饰器的形成过程 开放封闭原则 谈装饰器主要功能和装饰器固定结构 带参数的装饰器 多个装饰器装饰一个函数 返回顶部 楔子 作为一个会写函数的python开发,我们从今天开始要去公司上班 ...
随机推荐
- 消息队列queue
一.queue 在多线程编程中,程序的解耦往往是一个麻烦的问题,以及在socket网络编程中也会有这样的问题.recv 和send之间,如果服务端有消息,问题需要发送给客户端,而那边的recv 被主程 ...
- org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.bw.mapper.BillMapper.getBillList at org.apache.ibatis.binding.MapperMethod$SqlCommand.<init>(MapperMethod.java:225
这个错误是没有找到映射文件 org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.b ...
- 如何在 Linux 中查找最大的 10 个文件
https://linux.cn/article-9495-1.html
- Python3练习题 018:打印星号菱形
Python的内置方法 str.center(width [, fillchar]) 就能轻而易举打印出来:str即是数量不等的星号,width即是最大宽度(7个空格),默认填充字符fillchar就 ...
- 关于微信小程序使用canvas生成图片,内容图片跨域的问题
最近有个项目是保存为名片(图片),让用户发送给朋友或朋友圈,找了很多方案都不适用,绞尽脑汁之后还是选了使用canvas,但是用这玩意儿生成图片最大的缺点就是,如果你的内容中有图片,并且这个图片是通过外 ...
- HashMap深度解析(转载)
原文地址:http://blog.csdn.net/ghsau/article/details/16890151 实现原理:用一个数组来存储元素,但是这个数组存储的不是基本数据类型.HashMap实现 ...
- syncthing 多主机同步文件工具
周五看了下阮一峰的blog 看到有一个 syncthing的小工具挺好用的 进行了简单的尝试: 1. 下载文件位置: https://syncthing.net 2. 下载文件后的简单安装 绿色版直接 ...
- pHP生成唯一单号
这几天一直在写个人使用的用户中心,虽然期间遇到不少的问题,但还是一点点的都解决了,也从制作期间学到不少的知识,今天就说一说利用PHP生成订单单的方法. 订单号,大家都不陌生,无论从在网上购物,还是在线 ...
- Day 6-2简单的socket通信
什么是socket? Socket是应用层与TCP/IP协议族通信的中间软件抽象层,它是一组接口.在设计模式中,Socket其实就是一个门面模式,它把复杂的TCP/IP协议族隐藏在Socket接口后面 ...
- Day 4-5 序列化 json & pickle &shelve
序列化: 序列化是指把内存里的数据类型转变成字符串,以使其能存储到硬盘或通过网络传输到远程,因为硬盘或网络传输时只能接受bytes. 反序列化: 把字符转成内存里的数据类型. 用于序列化的两个模块.他 ...