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

怎么实现调用前的的时间?怎么实现调用后的时间?

两个时间都在修饰器里,是怎么做到两个时间不在同一个时间点的。

正在回答

4 回答

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

先记录t1时刻,接着执行调用r也就是f函数,调用完毕后,记录t2时刻,这样相减就是调用所用的时间啦

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

白白净净叫大星_03418722 提问者

f(*args,**kw)就相当于是调用的函数嘛
2017-08-01 回复 有任何疑惑可以回复我~
#2

猿子 回复 白白净净叫大星_03418722 提问者

确切的说应该是执行了函数
2017-08-24 回复 有任何疑惑可以回复我~

Python 支持格式化字符串的输出 ,最基本的用法是将一个值插入到一个有字符串格式符 %s 的字符串中。

print "My name is %s and weight is %d kg!" % ('Zara', 21)
   %f 格式化浮点数字,可指定小数点后的精度
%s 格式化字符串


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

回复 白白净净叫大星_03418722:

不用r直接调用f原函数也是一样的

def fn(*args,**kw):

        t1=time.time()

        f(*args,**kw)

        t2=time.time()

        print 'call %s() in %fs' % (f.__name__,(t2 - t1))

        return f(*args,**kw)


f()就是下面的factorial(n),调用了一遍

@performance

def factorial(n):

    return reduce(lambda x,y: x*y, range(1, n+1))


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

慕侠5763135

小姐姐,麻烦问一下第三个%是什么意思?
2017-08-06 回复 有任何疑惑可以回复我~
#2

冷月诗魂 回复 慕侠5763135

第一个%s表示f._name_ 第二个%fs表示t2-t1(浮点数,也就是有小数点),第三个%表示格式化,我的理解就是把和后面的参数分开来。
2017-09-12 回复 有任何疑惑可以回复我~
def performance(unit):
    def performance_decorator(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 performance_decorator
定义那么函数,实际意义是什么呢


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

举报

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

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

进入课程

怎么实现调用前的的时间?怎么实现调用后的时间?

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