首先,什么是函数修饰符?函数修饰符就是对原有函数做一层包装。比如有以下两个函数:
复制代码
def func1(): print 'I am function func1' def func2(): print 'I am function func2'
现在我们想为这两个函数增加一段共同的操作,这时就可以使用函数修饰符。首先我们定义一个修饰函数,先不做任何处理,仅仅打印一条横线:
复制代码
def de( f ) def call_(): print '-------------------------------' return f() return _call_
使用这个修饰符:
复制代码
def de( f ): def _call_(): print '-------------------------------' return f() return _call @de def func1(): print 'I am function func1' @de def func2(): print 'I am function func2' if name = '__main__':
func1()
func2()
运行结果为:
复制代码
d:\我的文档\桌面>b.py ------------------------------- I am function func1 ------------------------------- I am function func2 d:\我的文档\桌面>
可以看到,修饰符起作用了。 注意: 1.修饰符等价于包装调用:
@de def func1: ----- 等价于 ------ func1 = de( func1 )
2.修饰函数必须返回一个“可调用对象”:
def de( f ): def call_(): return f() return _call # 返回的是一个函数体,而非调用_call_()
下一个问题:如果各个被修饰函数有不同的参数,怎么处理呢?例如:
def func1( lst1, lst2 ): # 合并两个list,并打印各项 for item in lst1+lst2: print item def func2( dic ): # 循环dict,打印各key-value for k, v in dic.items(): print k, v
这两个函数参数不同,又都没有异常处理,现在我们想增加上,使用修饰符这样处理:
import sys import traceback def de( f ): def call_( *args, **kwargs ): try: return f( *args , **kwargs ) except: print 'param type error' return _call @de def func1( lst1, lst2 ): for item in lst1+lst2: print item @de def func2( dic ): for k, v in dic.items(): print k, v if name = '__main__': func1( [1,2], [3,4] ) func2( [1,2] )
这里使用了可变参数*args和**kwargs,这样会把所有接收来的参数,原样不动的再转给原函数,是惯用法。 以上程序运行结果: 复制代码
d:\我的文档\桌面>b.py 1 2 3 4 param type error d:\我的文档\桌面>