Python时间测量功能
问题内容:
我想创建一个python函数来测试在每个函数中花费的时间并打印其名称及其时间,我该如何打印该函数名称,如果还有其他方法可以这样做,请告诉我
def measureTime(a):
start = time.clock()
a()
elapsed = time.clock()
elapsed = elapsed - start
print "Time spent in (function name) is: ", elapsed
问题答案:
但是,如果您想严格地学习自己的计时方法,可以在这里开始使用装饰器。
Python 2:
def timing(f):
def wrap(*args):
time1 = time.time()
ret = f(*args)
time2 = time.time()
print '%s function took %0.3f ms' % (f.func_name, (time2-time1)*1000.0)
return ret
return wrap
用法非常简单,只需使用@timing装饰器即可:
@timing
def do_work():
#code
Python 3:
def timing(f):
def wrap(*args, **kwargs):
time1 = time.time()
ret = f(*args, **kwargs)
time2 = time.time()
print('{:s} function took {:.3f} ms'.format(f.__name__, (time2-time1)*1000.0))
return ret
return wrap
注意我正在调用f.func_name
以字符串形式获取函数名称(在Python 2中)或f.__name__
在Python 3中。