python装饰器的解决办法
内容摘要
这篇文章主要为大家详细介绍了python装饰器的简单示例,具有一定的参考价值,可以用来参考一下。
对python这个高级语言对此感兴趣的朋友,看看idc笔记做的技术笔记!
装饰器的语法
对python这个高级语言对此感兴趣的朋友,看看idc笔记做的技术笔记!
装饰器的语法
文章正文
这篇文章主要为大家详细介绍了python装饰器的简单示例,具有一定的参考价值,可以用来参考一下。
对python这个高级语言对此感兴趣的朋友,看看idc笔记做的技术笔记!装饰器的语法以@开头,接着是装饰器函数的名字、可选参数。
紧跟装饰器声明的是被装饰的函数和被装饰的函数的可选参数,如下:
@decorator(dec_opt_args)
def func(func_args):
....
其实总体说起来,装饰器其实也就是一个函数,一个用来包装函数的函数,装饰器在函数声明完成的时候被调用,调用之后声明的函数被换成一个被装饰器装饰过后的函数。
如:
# @param python基础 之 装饰器详解
# @author php教程|www.idcnote.com
def deco(func):
...
return func
@deco
def foo():
print 'foo'
#-----------------------------------
#等价如下:
def deco(func):
...
return func
def foo():
print 'foo'
foo = deco(foo)
如下例子:
def deco1(func):
print 'ok'
return func
@deco1
def foo():
print 'foo'
foo()
#输出--------------
#ok
#foo
#------------------
# End www_512pic_com
如果不使用装饰器,则可如下:
# @param python基础 之 装饰器详解
# @author php教程|www.idcnote.com
def deco1(func):
print 'ok'
return func
def foo():
print 'foo'
print foo #<function foo at 0x00AFE6F0>
foo = deco1(foo)
foo()
#输出--------------
#ok
#foo
#------------------
# End www_512pic_com
两者对比下,可发现使用装饰器是那么简便、灵活。特别是在企业级的开发上。
同时也可以多个装饰器重叠使用:
# @param python基础 之 装饰器详解
# @author php教程|www.idcnote.com
def deco1(func):
print 'deco1'
return func
def deco2(func):
print 'deco2'
return func
@deco1
@deco2
def foo():
print 'foo'
foo()
#输出如下:-----------
#deco2
#deco1
#foo
#---------------------
# End www_512pic_com
等效于:
# @param python基础 之 装饰器详解
# @author php教程|www.idcnote.com
@deco1
@deco2
def foo(arg):pass
-----------与下等效----------
foo = deco1(deco2(foo()))
# End www_512pic_com
二、有参、无参的装饰器
上面的例子基本上都是有参数的,无参数更为简单。
1、无参
@deco1
@deco2
def foo(arg):pass
---------------------
foo = deco1(deco2(foo()))
2、有参
@deco1(deco_arg)
@deco2
def foo(arg):pass
---------------------
foo = deco1(deco_arg)(deco2(foo()))
返回以函数作为参数的装饰器
三、用处
1、引用日志
2、增加计时逻辑来检测性能
3、给函数加入事务的能力
四、实例
# @param python基础 之 装饰器详解
# @author php教程|www.idcnote.com
from time import ctime,sleep
def deco(func):
def decoIn():
print '[%s]:%s called' %(ctime(),func.__name__)
return func
return decoIn
@deco
def foo():
pass
foo()
sleep(4)
for i in range(2):
sleep(1)
foo()
#输出如下:--------
#[Fri Jul 05 10:45:04 2013]:foo called
#[Fri Jul 05 10:45:09 2013]:foo called
#[Fri Jul 05 10:45:10 2013]:foo called
#------------------
# End www_512pic_com
注:关于python装饰器的简单示例的内容就先介绍到这里,更多相关文章的可以留意
代码注释