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

关于自己写的代码,为什么没有print call.....,求大神

#coding=utf8

import time, functools


def performance(unit):

    def fn(f):

        @functools.wraps(f)

        def wrapper(*args,**kw):

            t1 = time.time()

            kk = f(*args,**kw)

            t2 = time.time()

            print 'call %s ()in %s %s' % (f.__name__ , t2-t1, unit) if unit == 's' else (t2 - t1)*1000

            return kk

        return wrapper

    return fn


@performance('ms')

def factorial(n):

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

print factorial(3)

print factorial.__name__


正在回答

4 回答

你执行了这一段print factorial(3) 出现6有什么问题吗。 他会计算1*2*3的值啊。

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

代码:

#coding=utf8

import time, functools


def performance(unit):

    def fn(f):

        @functools.wraps(f)

        def wrapper(*args,**kw):

            t1 = time.time()

            kk = f(*args,**kw)

            t2 = time.time()

            t = t2 - t1 if unit == 's' else (t2 - t1)*1000

            print 'call %s ()in %s %s' % (f.__name__ , t, unit) 

            return kk

        return wrapper

    return fn


@performance('ms')

def factorial(n):

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

    

print factorial(3)

print factorial.__name__


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

那就在这开个新问题把,代码运行完 后面有个6 是为什么 

call factorial() in 0.00381469726562 ms
6
factorial

其他同学写的代码运行后,也有这个问题

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

我懂了, 。。。。 低级错误。  我还以为可以灵性的 把if 后面的 ms和s 替换

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

举报

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

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

进入课程

关于自己写的代码,为什么没有print call.....,求大神

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