python3 装饰器
短信预约 -IT技能 免费直播动态提醒
看廖雪峰官网的python3装饰器有感
装饰器即将一个函数作为变量在新的函数中调用此函数。
作业:
能否写出一个@log的decorator,使它既支持:
@logdef f():
pass
又支持:
@log('execute')def f():
pass
例1:
import functools
import time
def log(*args,**kwargs): # *args 是个元组
if args and isinstance(args,tuple): #log()
def decorator(func):
@functools.wraps(func)
def wrapper(*args1,**kwargs1):
print("1111 %s %s()" %(args[0],func.__name__))
#return func
return func(*args1,**kwargs1)
return wrapper
return decorator
else:
def decorator(func):
@functools.wraps(func)
def wrapper(*args1,**kwargs1):
print("222 %s()" % func.__name__)
return func(*args1,**kwargs1)
return wrapper
return decorator
@log('test')
def now1():
print(time.time())
now1()
@log()
def now2():
print(time.time())
now2()
result:得到两个函数调用log装饰器的结果。
1111 test now1()
1505878800.4148097
222 now2()
1505878800.4148097
网站链接:廖雪峰python3装饰器
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341