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

在这个表示使用时间的装饰器里, print 'call %s() in %fs' % (f.__name__, (t2 - t1))的意思,求详细解释……

import time

def performance(f):
    def fn(*args,**kw):
        t1=time.time()
        r=f(*args,**kw)
        t2=time.time()
        print 'call %s() in %fs' % (f.__name__, (t2 - t1))
        return r
    return fn

@performance
def factorial(n):
    return reduce(lambda x,y: x*y, range(1, n+1))

print factorial(10)

正在回答

3 回答

%是格式化的意思,%s是格式化字符串,%f是格式化浮点数,这句话的意思是把f.__name__插入到了%s这个位置,(t2-t1)计算后的值插入到了%f这个位置

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

Vaquish 提问者

谢谢!
2015-03-06 回复 有任何疑惑可以回复我~
#2

目送

他不是要打印时间吗?用了t2-t1后打印出来的时间为0啊
2016-02-25 回复 有任何疑惑可以回复我~

举报

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

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

进入课程

在这个表示使用时间的装饰器里, print 'call %s() in %fs' % (f.__name__, (t2 - t1))的意思,求详细解释……

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