Python装饰器用法实例分析

时间:2021-05-22

本文实例讲述了Python装饰器用法。分享给大家供大家参考,具体如下:

无参数的装饰器

#coding=utf-8def log(func): def wrapper(): print 'before calling ',func.__name__ func() print 'end calling ',func.__name__ return wrapper@logdef hello(): print 'hello'@logdef hello2(name): print 'hello',nameif __name__=='__main__': hello()

运行结果:

before calling hello
hello
end calling hello

带参数的装饰器:

#coding=utf-8def log(func): def wrapper(name): print 'before calling ',func.__name__ func(name) print 'end calling ',func.__name__ return wrapper@logdef hello(name): print 'hello',name@logdef hello2(name): print 'hello',nameif __name__=='__main__': hello('haha')

运行结果:

before calling hello
hello haha
end calling hello

多个参数的时候:

#coding=utf-8def log(func): ''' *无名字的参数 **有名字的参数 :param func: :return: ''' def wrapper(*args,**kvargs): print 'before calling ',func.__name__ print 'args',args,'kvargs',kvargs func(*args,**kvargs) print 'end calling ',func.__name__ return wrapper@logdef hello(name,age): print 'hello',name,age@logdef hello2(name): print 'hello',nameif __name__=='__main__': hello('haha',2) hello(name='hehe',age=3)

输出:

end calling hello
before calling hello
args () kvargs {'age': 3, 'name': 'hehe'}
hello hehe 3
end calling hello

装饰器里带参数的情况

本质就是嵌套函数

#coding=utf-8def log(level,*args,**kvargs): def inner(func): def wrapper(*args,**kvargs): print level,'before calling ',func.__name__ print level,'args',args,'kvargs',kvargs func(*args,**kvargs) print level,'end calling ',func.__name__ return wrapper return inner@log(level='INFO')def hello(name,age): print 'hello',name,age@logdef hello2(name): print 'hello',nameif __name__=='__main__': hello('haha',2)

运行输出:

INFO before calling hello
INFO args ('haha', 2) kvargs {}
hello haha 2
INFO end calling hello

更多关于Python相关内容可查看本站专题:《Python数据结构与算法教程》、《Python Socket编程技巧总结》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》及《Python入门与进阶经典教程》

希望本文所述对大家Python程序设计有所帮助。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章