首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用time模块测量运行时间

使用time模块测量运行时间
EN

Stack Overflow用户
提问于 2010-09-02 02:17:56
回答 7查看 510.1K关注 0票数 367

使用python中的time模块,可以测量经过的时间吗?如果是这样,我该怎么做呢?

我需要这样做,这样如果光标在小部件中停留了一定的时间,事件就会发生。

EN

回答 7

Stack Overflow用户

回答已采纳

发布于 2010-09-02 02:22:03

代码语言:javascript
复制
start_time = time.time()
# your code
elapsed_time = time.time() - start_time

您还可以编写简单的装饰器来简化对各种函数执行时间的测量:

代码语言:javascript
复制
import time
from functools import wraps

PROF_DATA = {}

def profile(fn):
    @wraps(fn)
    def with_profiling(*args, **kwargs):
        start_time = time.time()

        ret = fn(*args, **kwargs)

        elapsed_time = time.time() - start_time

        if fn.__name__ not in PROF_DATA:
            PROF_DATA[fn.__name__] = [0, []]
        PROF_DATA[fn.__name__][0] += 1
        PROF_DATA[fn.__name__][1].append(elapsed_time)

        return ret

    return with_profiling

def print_prof_data():
    for fname, data in PROF_DATA.items():
        max_time = max(data[1])
        avg_time = sum(data[1]) / len(data[1])
        print "Function %s called %d times. " % (fname, data[0]),
        print 'Execution time max: %.3f, average: %.3f' % (max_time, avg_time)

def clear_prof_data():
    global PROF_DATA
    PROF_DATA = {}

用法:

代码语言:javascript
复制
@profile
def your_function(...):
    ...

您可以同时分析多个功能。然后,要打印测量结果,只需调用print_prof_data():

票数 549
EN

Stack Overflow用户

发布于 2010-09-02 02:28:25

time.time()将会完成这项工作。

代码语言:javascript
复制
import time

start = time.time()
# run your code
end = time.time()

elapsed = end - start

你可能想看看this的问题,但我不认为它是必要的。

票数 97
EN

Stack Overflow用户

发布于 2017-10-03 20:04:18

对于想要更好地格式化的用户,

代码语言:javascript
复制
import time
start_time = time.time()
# your script
elapsed_time = time.time() - start_time
time.strftime("%H:%M:%S", time.gmtime(elapsed_time))

将打印出来,持续2秒:

代码语言:javascript
复制
'00:00:02'

7分钟一秒:

代码语言:javascript
复制
'00:07:01'

请注意,gmtime的最小时间单位是秒。如果您需要微秒,请考虑以下几点:

代码语言:javascript
复制
import datetime
start = datetime.datetime.now()
# some code
end = datetime.datetime.now()
elapsed = end - start
print(elapsed)
# or
print(elapsed.seconds,":",elapsed.microseconds) 

strftime documentation

票数 88
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3620943

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档