Python 装饰器
2017-07-29 20:13
337 查看
装饰器 decorator:可动态为函数添加新的功能
使用方法:
import time
def performance(f): #定义装饰器函数,并传入需要被包装的函数
def fn(*args, **kw): #对传进来的函数进行包装的函数,此参数自适应任何参数定义的函数
t_start = time.time() #记录函数开始时间
r = f(*args, **kw) #调用函数
t_end = time.time() #记录函数结束时间
print 'call %s() in %fs' % (f.__name__, (t_end - t_start)) #打印调用函数的属性信息,并打印调用函数所用的时间
return r #返回包装后的函数
return fn #调用包装后的函数
@performance #调用装饰器
def factorial(n): #定义乘数函数(需要包装的函数)
return reduce(lambda x, y: x * y, range(1, n + 1))
print factorial(10)
上述装饰器属于无参装饰器,含参装饰器参考http://www.imooc.com/code/6066
带参数的log函数首先返回一个decorator函数,再让这个decorator函数接收原函数并返回新函数
import time
def performance(unit):
def p_decorator(f):
def fn(*args, **kw):
t_start = time.time()
r = f(*args, **kw)
t_end = time.time()
print 'call %s() in %f%s' % (f.__name__, (t_end - t_start)*1000,unit)
return r
return fn
return p_decorator
@performance('ms')
def factorial(n):
return reduce(lambda x,y: x*y, range(1, n+1))
print factorial(10)
有时候我们需要将原函数的一些属性复制到新函数中
Python内置的functools可以用来自动化完成这个“复制”的任务
import time, functools
def performance(unit):
def p_decorator(f):
@functools.wraps(f)
def fn(*args, **kw):
t_start = time.time()
r = f(*args, **kw)
t_end = time.time()
print 'call %s() in %f%s' % (f.__name__, (t_end - t_start)*1000,unit)
return r
return fn
return p_decorator
@performance('ms')
def factorial(n):
return reduce(lambda x,y: x*y, range(1, n+1))
print factorial.__name__
使用方法:
import time
def performance(f): #定义装饰器函数,并传入需要被包装的函数
def fn(*args, **kw): #对传进来的函数进行包装的函数,此参数自适应任何参数定义的函数
t_start = time.time() #记录函数开始时间
r = f(*args, **kw) #调用函数
t_end = time.time() #记录函数结束时间
print 'call %s() in %fs' % (f.__name__, (t_end - t_start)) #打印调用函数的属性信息,并打印调用函数所用的时间
return r #返回包装后的函数
return fn #调用包装后的函数
@performance #调用装饰器
def factorial(n): #定义乘数函数(需要包装的函数)
return reduce(lambda x, y: x * y, range(1, n + 1))
print factorial(10)
上述装饰器属于无参装饰器,含参装饰器参考http://www.imooc.com/code/6066
带参数的log函数首先返回一个decorator函数,再让这个decorator函数接收原函数并返回新函数
import time
def performance(unit):
def p_decorator(f):
def fn(*args, **kw):
t_start = time.time()
r = f(*args, **kw)
t_end = time.time()
print 'call %s() in %f%s' % (f.__name__, (t_end - t_start)*1000,unit)
return r
return fn
return p_decorator
@performance('ms')
def factorial(n):
return reduce(lambda x,y: x*y, range(1, n+1))
print factorial(10)
有时候我们需要将原函数的一些属性复制到新函数中
Python内置的functools可以用来自动化完成这个“复制”的任务
import time, functools
def performance(unit):
def p_decorator(f):
@functools.wraps(f)
def fn(*args, **kw):
t_start = time.time()
r = f(*args, **kw)
t_end = time.time()
print 'call %s() in %f%s' % (f.__name__, (t_end - t_start)*1000,unit)
return r
return fn
return p_decorator
@performance('ms')
def factorial(n):
return reduce(lambda x,y: x*y, range(1, n+1))
print factorial.__name__
相关文章推荐
- Python: 使用装饰器“@”取得函数执行时间
- Python中使用装饰器时需要注意的一些问题
- 第二天 Python3.4.2 函数是第一等公民 装饰器
- (转)Python装饰器与面向切面编程
- python第九篇 装饰器
- Python装饰器学习
- 深入理解Python装饰器
- Python装饰器
- Python基础-装饰器
- Python基础语法(3)——文件流、异常处理、面向对象编程以及装饰器
- Python装饰器学习(九步入门)
- python第四天学习记录——装饰器、生成器、内置函数
- python中装饰器与元类的使用
- 装饰器实现Python web框架路由功能
- python3.6面向对象的多继承与装饰器
- 12步轻松搞定python装饰器
- 深入理解Python装饰器
- 深入理解Python中装饰器的用法
- 对于Python装饰器使用的一些建议
- Python基础-装饰器