文章转载自python 中 exec、 eval、 execfile 和 compile 用法.当然,这里的版本应该比较老了.
exec
语句用来执行储存在字符串或文件中的Python
语句。例如,我们可以在运行时生成一个包含Python
代码的字符串,然后使用exec
语句执行这些语句。下面是一个简单的例子。
>>> exec 'print "Hello World"'
Hello World
eval
语句用来计算存储在字符串中的有效Python
表达式。下面是一个简单的例子。
>>> eval_r('2*3')
6
eval_r(str [ globals [ locals ]])
函数将字符串str
当成有效python
表达式来求值,并返回计算结果。
同样地,exec
语句将字符串str
当成有效Python
代码来执行.提供给exec
的代码的名称空间和exec
语句的名称空间相同.
最后,execfile(filename [,globals [,locals ]])
函数可以用来执行一个文件,看下面的例子:
>>> eval_r('3+4')
7
>>> exec 'a=100'
>>> a
100
>>> execfile(r'd:\code\ex\test.py')
hello world!
>>>
默认的,eval_r()
,exec,execfile()
所运行的代码都位于当前的名字空间中. eval_r()
, exec
和 execfile()
函数也可以接受一个或两个可选字典参数作为代码执行的全局名字空间和局部名字空间. 例如:
globals = { 'x': 7,
'y': 10,
'birds': ['Parrot', 'Swallow', 'Albatross']
}
locals = { }
# 将上边的字典作为全局和局部名称空间
a = eval("3*x + 4*y", globals, locals)
exec "for b in birds: print b" in globals, locals # 注意这里的语法
execfile("foo.py", globals, locals)
如果你省略了一个或者两个名称空间参数,那么当前的全局和局部名称空间就被使用.如果一个函数体内嵌嵌套函数或lambda
匿名函数时,同时又在函数主体中使用exec
或execfile()
函数时, 由于牵到嵌套作用域,会引发一个SyntaxError异常.
此段原文如下:
If you omit one or both namespaces, the current values of the global and local namespaces are used. Also,due to issues related to nested scopes, the use of exec or execfile() inside a function body may result in a SyntaxError exception if that function also contains nested function definitions or uses the lambda operator.)
注意例子中exec
语句的用法和eval_r()
, execfile()
是不一样的. exec
是一个语句(就象print
或while
), 而eval_r()
和execfile()
则是内建函数.
exec(str)
这种形式也被接受,但是它没有返回值。
当一个字符串被exec
,eval_r()
,或execfile()
执行时,解释器会先将它们编译为字节代码,然后再执行.这个过程比较耗时,所以如果需要对某段代码执行很多次时,最好还是对该代码先进行预编译,这样就不需要每次都编译一遍代码,可以有效提高程序的执行效率。
compile(str ,filename ,kind)
函数将一个字符串编译为字节代码, str
是将要被编译的字符串, filename
是定义该字符串变量的文件,kind
参数指定了代码被编译的类型– 'single'
指单个语句, 'exec'
指多个语句, 'eval'
指一个表达式. cmpile()
函数返回一个代码对象,该对象当然也可以被传递给eval_r()
函数和exec
语句来执行,例如:
>>> str = 'for i in range(0, 10): print i'
>>> c = compile(str,'','exec') # 编译为字节代码对象
>>> exec c # 执行
0
1
2
3
4
5
6
7
8
9
>>>
>>> str2 = '3*6 + 4*8'
>>> c2 = compile(str2,'','eval') # 编译为表达式
>>> result = eval_r(c2) # 执行
>>> result
50
>>>