首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >python: slow timeit()函数

python: slow timeit()函数
EN

Stack Overflow用户
提问于 2009-08-10 23:09:51
回答 4查看 8K关注 0票数 19

当我在timeit()之外运行下面的代码时,它似乎是瞬间完成的。但是,当我在timeit()函数中运行它时,它花费的时间要长得多。为什么?

代码语言:javascript
复制
>>> import timeit
>>> t = timeit.Timer("3**4**5")
>>> t.timeit()
16.55522028637718

使用:Python3.1 (x86) - AMD Athlon 64 X2 - WinXP (32位)

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2009-08-10 23:12:42

timeit()函数多次运行代码(默认为一百万次),并取平均计时时间。

要仅运行代码一次,请执行以下操作:

代码语言:javascript
复制
t.timeit(1)

但这会给你带来扭曲的结果--这是有充分理由重复的。

要获得每个循环的重复时间,请将结果除以循环的数量。如果一百万次太多,请使用较小的值作为重复次数:

代码语言:javascript
复制
count = 1000
print t.timeit(count) / count
票数 32
EN

Stack Overflow用户

发布于 2009-08-10 23:13:26

因为timeit默认运行一百万次。重点是做微基准,而获得短事件的准确时间的唯一方法是多次重复它们。

票数 6
EN

Stack Overflow用户

发布于 2009-08-10 23:18:13

根据docs,Timer.timeit()默认情况下会运行您的代码一百万次。使用"number“参数更改此默认值:

代码语言:javascript
复制
t.timeit(number=100)

例如。

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

https://stackoverflow.com/questions/1257727

复制
相关文章

相似问题

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