最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

Python的装饰器用法学习笔记

来源:懂视网 责编:小采 时间:2020-11-27 14:29:15
文档

Python的装饰器用法学习笔记

Python的装饰器用法学习笔记:在python中常看到在定义函数是使用@func. 这就是装饰器, 装饰器是把一个函数作为参数的函数,常常用于扩展已有函数,即不改变当前函数状态下增加功能. def run(): print I'm run. 我有这么一个函数, 我想知道这个函数什么时候开始什么时候结束. 我应该
推荐度:
导读Python的装饰器用法学习笔记:在python中常看到在定义函数是使用@func. 这就是装饰器, 装饰器是把一个函数作为参数的函数,常常用于扩展已有函数,即不改变当前函数状态下增加功能. def run(): print I'm run. 我有这么一个函数, 我想知道这个函数什么时候开始什么时候结束. 我应该

在python中常看到在定义函数是使用@func. 这就是装饰器, 装饰器是把一个函数作为参数的函数,常常用于扩展已有函数,即不改变当前函数状态下增加功能.

def run():
 print "I'm run."

我有这么一个函数, 我想知道这个函数什么时候开始什么时候结束. 我应该这么写

def run():
 print time.ctime()
 print "I'm run."
 print time.ctime()

但是如果不允许修改函数的话就需要装饰器了

def count(func):
 def wrapper():
 print time.ctime()
 ret = func()
 print time.ctime()
 return ret
 return wrapper

@count
def run():
 print "I'm run."

 # print '2015-4-10'

eg:

def now():
 print '2015-4-10'
f = now
f() 

函数有一个__name__ 对象 可通过 dir(func) func为定义的函数名

now.__name__ # print 'now'
f.__name__ # print 'now'

print f # print ''
print now # print ''

我们通过装饰器打印log日志

def log(func):
 def wrapper(*args, **kwargs):
 print "call %s()" % func.__name__
 return func(*args, **kwargs)
 return wrapper

@log
def now():
 print '2015-4-10'

now() # print 'call now()'

其实装饰器修饰函数相当于, now = log(now) 也就是装饰器函数把被修饰的函数当参数后赋给同名的变量

functools.wraps 函数

当我们使用了装饰器后now的__name__值发生了改变

# 没有使用前
now.__name__ # print 'now'
# 使用后
now.__name__ # print 'wrapper'

当我们使用装饰器前,now.__name__使用的是当前now函数,但使用后 now这个函数其实是 log(now) 也就是log函数的返回值也就是被包裹的wrapper. 解决方法是functools.wraps函数.

装饰闭包, 使用前得调用 import functools

def log(func):
 @functools.wraps(func)
 def wrapper(*args, **kwargs):
 ...

带参数的装饰器

如果decorator需要传入参数, 那就需要在写一个返回decorator的高阶函数. 写出来更复杂.

def login(level):
 def _deco(func):
 def wrapper(*args, **kwargs):
 if level >= 5:
 print '用户 VIP 等级 %d' % int(level-5)
 else:
 print '用户 屌丝 等级 %d' % abs(level-5)
 return func(*args, **kwargs)
 return wrapper
 return _deco

@login(5)
def user(username):
 print 'welcome, %s' % username

# 用户vip 等级0
# welcome, mink
user('mink')

带参数的decorator等于func = 装饰器函数(装饰器参数)(func)

装饰器类

通过类的__call__可以想使用函数一样使用类

class A(object):
 def __init__(self, func):
 self.func = func

 def __call__(self):
 return self.func() ** 2

@A
def foo():
 return 10

print foo() # print 100

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

Python的装饰器用法学习笔记

Python的装饰器用法学习笔记:在python中常看到在定义函数是使用@func. 这就是装饰器, 装饰器是把一个函数作为参数的函数,常常用于扩展已有函数,即不改变当前函数状态下增加功能. def run(): print I'm run. 我有这么一个函数, 我想知道这个函数什么时候开始什么时候结束. 我应该
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top