python装饰器常见使用方法分析
本文实例讲述了python装饰器常见使用方法。分享给大家供大家参考,具体如下:
python的装饰器,可以用来实现,类似springAOP类似的功能。一样可以用来记录某个方法执行前做什么,执行后做什么,或者用来记录日志,运行的时间等,更有甚者,用这个来做权限拦截,也未尝不可。从两个方面来描述python的装饰模式:
1.对普通方法的装饰
2.对在class类中的方法的装饰,不需要给参数的情况
3.对在class类中的方法的装饰,需要给参数的情况
一,对普通方法的装饰。比如,要计算一个一个方法执行的时间.
#coding:utf-8 importtime deftimeit(func): defwrapper(*args,**kv): start=time.clock() print'开始执行' func(*args,**kv) end=time.clock() print'花费时间:',end-start returnwrapper @timeit deffoo(): print'infoo()' if__name__=='__main__': foo()
运行结果:
开始执行
infoo()
花费时间:6.55415628267e-05
可以看到,计算出了时间差。而不是像普通方法一样,写在一个函数里面实现。
二、对在class类中的方法的装饰,不需要给参数的情况
#coding:utf-8 importtime deftimeit(func): defwrapper(*args,**kv): start=time.clock() print'开始执行' func(*args,**kv) end=time.clock() print'花费时间:',end-start returnwrapper classMySpendTime(object): def__init__(self): pass @timeit deffoo(self): print'infoo()' spendtime=MySpendTime() spendtime.foo()
运行结果:
开始执行
infoo()
花费时间:4.42208134735e-05
三、对在class类中的方法的装饰,需要给参数的情况
#coding:utf-8
'''
Createdon2012-11-1
@author:yihaomen.com
'''
defUpdateUI(msg,step):
printu"内容:",msg
printu"步骤:到第%s步了"%step
defdec(func):
defwapper(self,*args,**kwargs):
func(self,*args,**kwargs)
returnwapper
returndec
classCommand(object):
defExcute(self):
self.Work1st()
self.Work2nd()
self.Work3rd()
@UpdateUI("开始第一步","1")
defWork1st(self):
print"Work1st"
@UpdateUI("开始第二步",2)
defWork2nd(self):
print"Work2nd"
@UpdateUI("开始第三步",3)
defWork3rd(self):
print"Work3rd"
if__name__=="__main__":
command=Command()
command.Excute()
运行结果:
内容:开始第一步
步骤:到第1步了
内容:开始第二步
步骤:到第2步了
内容:开始第三步
步骤:到第3步了
Work1st
Work2nd
Work3rd
更多关于Python相关内容可查看本站专题:《Python数据结构与算法教程》、《PythonSocket编程技巧总结》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》及《Python入门与进阶经典教程》
希望本文所述对大家Python程序设计有所帮助。