3

其中两个语句运行,而另一个因语法错误而失败。我究竟做错了什么?

>>> Timer('for i in xrange(10): oct(i)').repeat(3)
[2.7091379165649414, 2.6934919357299805, 2.689150094985962]
>>> Timer('n = [] ; n = [oct(i) for i in xrange(10)]').repeat(3)
[4.0500171184539795, 3.6979520320892334, 3.701982021331787]
>>> Timer('n = [] ; for i in xrange(10): n.append(oct(i))').repeat(3)
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/opt/local/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/timeit.py", line 136, in __init__
    code = compile(src, dummy_src_name, "exec")
  File "<timeit-src>", line 6
    n = [] ; for i in xrange(10): n.append(oct(i))
               ^
SyntaxError: invalid syntax
4

3 回答 3

7

您失败的陈述在语法上不正确。如果您需要在一个函数中定义多个语句的时间并调用 Timer,则在从 main 导入函数后

>>> def foo():
    n = []
    for i in xrange(10): n.append(oct(i))    

>>> Timer("foo()","from __main__ import foo")

现在您需要了解为什么失败的语句不正确

复合语句的文档摘录

一个套件可以是一个或多个以分号分隔的简单语句,位于与标题相同的行上,位于标题的冒号之后,或者它可以是一个或多个在后续行中的缩进语句。

stmt_list     ::=  simple_stmt (";" simple_stmt)* [";"]

同样,一个简单的语句

simple_stmt ::=  expression_stmt
                 | assert_stmt
                 | assignment_stmt
                 | augmented_assignment_stmt
                 | pass_stmt
                 | del_stmt
                 | print_stmt
                 | return_stmt
                 | yield_stmt
                 | raise_stmt
                 | break_stmt
                 | continue_stmt
                 | import_stmt
                 | global_stmt
                 | exec_stmt

您现在应该清楚何时可以(不应该)使用分号。

于 2012-04-16T14:46:19.827 回答
6
Timer('n = []\nfor i in xrange(10): n.append(oct(i))').repeat(3)
[2.026008492408778, 2.065228002189059, 2.048982731136192]
于 2012-04-16T14:41:57.080 回答
3

您也可以使用三引号

statement = '''n = []
for i in xrange(10):
    n.append(oct(i))'''

Timer(statement).repeat(3)
于 2015-04-26T16:17:36.110 回答