码迷,mamicode.com
首页 > 编程语言 > 详细

python 装饰器

时间:2020-05-22 21:42:35      阅读:80      评论:0      收藏:0      [点我收藏+]

标签:print   div   import   pre   rpe   __name__   timer   pen   name   

#函数返回值+1
def make(func):
    def wrapper(*args,**kwds):
        return func(*args,**kwds) + 1
    return wrapper

@make
def add():
    return 4

print add()  #输出5
#函数返回值+N
def makearg(num):
    def make(func):
        def wrapper(*args,**kwds):
            return func(*args,**kwds) + num
        return wrapper
    return make

@makearg(num=1)
def add(n):
    return n + 4
    
print add(4) # 输出9

装饰器传参 参考 https://www.cnblogs.com/serpent/p/9445592.html
#检测函数执行时间
import time
import sys
def timer(func):
    def wrapper(*args,**kwds):
        start=time.time()
        func(*args,**kwds)
        end=time.time()
        print "exe function %s take %s time" %(func.__name__,str(end - start))
    return wrapper

@timer
def add():
    print "start"
    time.sleep(5)
    print "ending"

add()

 

python 装饰器

标签:print   div   import   pre   rpe   __name__   timer   pen   name   

原文地址:https://www.cnblogs.com/jkklearn/p/12939657.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!