在回答这个问题时(并且已经阅读了类似问题的答案),我认为我知道Python如何缓存正则表达式.
但后来我想我会测试它,比较两种情况:
然而,结果是惊人的(在Python 3.3中):
>>> import timeit
>>> timeit.timeit(setup="import re",
... stmt='r=re.compile(r"\w+")\nfor i in range(10):\n r.search(" jkdhf ")')
18.547793477671938
>>> timeit.timeit(setup="import re",
... stmt='for i in range(10):\n re.search(r"\w+"," jkdhf ")')
106.47892003890324
Run Code Online (Sandbox Code Playgroud)
这慢了5.7倍!在Python 2.7中,仍然增加了2.5倍,这也超出了我的预期.
在Python 2和3之间是否更改了正则表达式的缓存?文档似乎没有暗示这一点.