为了账号安全,请及时绑定邮箱和手机立即绑定

能请各位大佬解释下每一行的语句

def performance(unit):
    def perf_decorator(f):
        @functools.wraps(f)
        def wrapper(*args, **kw):
            t1 = time.time()
            r = f(*args, **kw)
            t2 = time.time()
            t = (t2 - t1) * 1000 if unit=='ms' else (t2 - t1)
            print 'call %s() in %f %s' % (f.__name__, t, unit)
            return r
        return wrapper
    return perf_decorator


正在回答

4 回答

def performance(unit):#创建带参数的decorator,其中unit为参数的形参
    def perf_decorator(f):#定义装饰器函数
         @functools.wraps(f)#将原函数f的所有属性复制到新函数wrapper     
         def wrapper(*args, **kw):#定义装饰函数
             t1 = time.time()#记录函数开始时间         
             r = f(*args, **kw)#运行函数f            
             t2 = time.time()#记录函数结束时间            
             t = (t2 - t1) * 1000 if unit=='ms' else (t2 - t1)#计算函数f的运行时间            
             print 'call %s() in %f %s' % (f.__name__, t, unit)#打印函数f的名称,运行时间以及所带参数的实参            
             return r#调用原函数f
         return wrapper#返回装饰函数
    return perf_decorator#返回装饰器函数


28 回复 有任何疑惑可以回复我~
#1

qq_Burstsky_0 提问者

非常感谢!
2018-07-18 回复 有任何疑惑可以回复我~
#2

qq_Burstsky_0 提问者

能麻烦再解释下为什么要定义3层函数吗
2018-07-19 回复 有任何疑惑可以回复我~
#3

qq_天涯_81 回复 qq_Burstsky_0 提问者

因为要打印自定义的字符串呀,每层函数的参数都是不同的,第一层函数的参数是传入要打印的字符串,第二层函数的参数是原函数,第三层函数的参数是原函数的参数;定义两层的话,应该就只能打印固定的字符串了(函数名除外)
2018-07-19 回复 有任何疑惑可以回复我~
#4

925755208

为什么写成@functools.wraps(f),而不是@functools.wrapper(f)
2018-09-13 回复 有任何疑惑可以回复我~
查看2条回复

此段代码中的print 'call %s() in %f %s' % (f.__name__, t, unit)不会打印在控制台吗

0 回复 有任何疑惑可以回复我~
#1

慕标7383595

笨了,没调用函数,输出啥呀输出
2019-04-24 回复 有任何疑惑可以回复我~

解释的很到位,哈哈

0 回复 有任何疑惑可以回复我~

如此解释,还可以

0 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消
python进阶
  • 参与学习       255665    人
  • 解答问题       2949    个

学习函数式、模块和面向对象编程,掌握Python高级程序设计

进入课程

能请各位大佬解释下每一行的语句

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信