Python可执行对象——exec、eval、compile

       Python提供的调用可执行对象的内建函数进行说明,涉及exec、eval、compile三个函数。exec语句用来执行存储在代码对象、字符串、文件中的Python语句,eval语句用来计算存储在代码对象或字符串中的有效的Python表达式,而compile语句则提供了字节编码的预编译。
python

exec的使用

image

eval的使用

       本函数是用来动态地执行一个表达式的字符串,或者compile函数编译出来的代码对象。参数expression是一个表达式字符串,或者表示编译出来代码对象的名称;参数globals是全局命名空间,能够指定执行表达式时的全局做用域的范围,好比指定某些模块能够使用。若是本参数缺省,就使用当前调用这个函数的当前全局命名空间;参数locals是局部做用域命名空间,是用来指定执行表达式时访问的局部命名空间。若是全局命名空间参数出现,但缺省内置模块,那么会自动拷贝这个模块到全局命名空间,意味着不管怎么设置,均可以使用内置模块。若是两个命名空间,都使用缺省方式,就会使用调用这个函数时的命名空间来查找相应的变量。正则表达式

      为何要使用这个函数呢?这个函数的缘由,应该就是动态语言与编译语言的差异之处,由于在编译语言里要动态地产生代码,基本上是不可能的,但动态语言是能够,意味着软件已经部署到服务器上了,但只要做不多的更改,只好直接修改这部分的代码,就可当即实现变化,不用整个软件从新加载。另一个,这个功能能够用来机器学习里,好比根据用户使用这个软件频率,以及方式,可动态地修改代码,适应用户的变化。想到这里,是否是具备生命力的能力,能够自我更新代码,实现改良式进步,若是作破坏性的动做,其实就是一个病毒。使用exec和eval必定要注意安全性问题,尤为是网络环境中,可能给予他人执行非法语句的机会。express

     eval就是python做为动态语言的一个特色。可用做如下用途;安全

    (1) 动态构造参数服务器

opts=struct.uppack(eval("b'%ds'"%(opts_len)),ip_header[20:])

   (2)从外部字符串中生成python对象网络

image

 

要想更安全的使用 eval , 参考:机器学习

http://code.activestate.com/recipes/496746-restricted-safe-/函数

http://stackoverflow.com/questions/15197673/using-pythons-eval-vs-ast-literal-eval学习

 

compile的使用

格式:compile( str, file, type )编码

compile语句是从type类型(包括’eval’: 配合eval使用,’single’: 配合单一语句的exec使用,’exec’: 配合多语句的exec使用)中将str里面的语句建立成代码对象。file是代码存放的地方,一般为”。

compile语句的目的是提供一次性的字节码编译,就不用在之后的每次调用中从新进行编译了。

还须要注意的是,这里的compile和正则表达式中使用的compile并不相同,尽管用途同样。

 

>>> eval_code = compile( '1+2', '', 'eval')
>>> eval_code
<code object <module> at 0142ABF0, file "", line 1>
>>> eval(eval_code)
3

>>> single_code = compile( 'print "pythoner.com"', '', 'single' )
>>> single_code
<code object <module> at 01C68848, file "", line 1>
>>> exec(single_code)
pythoner.com

>>> exec_code = compile( """for i in range(5):
...   print "iter time: %d" % i""", '', 'exec' )
>>> exec_code
<code object <module> at 01C68968, file "", line 1>
>>> exec(exec_code)
iter time: 0
iter time: 1
iter time: 2
iter time: 3
iter time: 4
相关文章
相关标签/搜索