专栏首页python3python compile、eval、

python compile、eval、

  1. compile函数

    compile()函数允许程序员在运行时刻迅速生成代码对象,然后就可以用exec 语句或者内建函数eval()来执行这些对象或者对它们进行求值。一个很重要的观点是:exec 和eval()都可以执行字符串格式的Python 代码。当执行字符串形式的代码时,每次都必须对这些代码进行字节编译处理。compile()函数提供了一次性字节代码预编译,以后每次调用的时候,都不用编译了。

    compile(source, filename, mode[, flags[, dont_inherit]])    

    第一参数代表了要编译的python 代码。第二个字符串,虽然是必需的,但通常被置为空串。mode参数是个字符串,它用来表明代码对象的类型。有三个可能值:

    'eval' 可求值的表达式[和eval()一起使用]

    'single' 单一可执行语句[和exec或eval()一起使用]

    'exec' 可执行语句组[和exec一起使用]

可求值表达式

>>> eval_code = compile('100 + 200', '', 'eval')
>>> eval(eval_code)
300

单一可执行语句

>>> single_code = compile('print "Hello world!"', '', 'single')
>>> single_code
<code object <module> at 0xb76ebd10, file "", line 1>
>>> exec single_code
Hello world!
>>> eval(eval_code)
Hello world!

可执行语句组

>>> exec_code = compile("""
... req = input('Count how many numbers? ')
... for eachNum in range(req):
... print eachNum
... """, '', 'exec')
>>> exec exec_code
Count how many numbers? 6
0
1
2
3
4
5

2.eval函数

    eval()对表达式求值,后者可以为字符串或内建函数complie()创建的预编译代码对象。

    eval(source[, globals[, locals]])

    第二个和第三个参数,都为可选的,分别代表了全局和局部名字空间中的对象。如果给出这两个参数,globals 必须是个字典,locals可以是任意的映射对象,比如,一个实现了__getitem__()方法的对象。(在2.4 之前,local 必须是一个字典)如果都没给出这两个参数,分别默认为globals()和locals()返回的对象,如果只传入了一个全局字典,那么该字典也作为locals 传入。

>>> eval('100 + 200')
300

3.exec语句

    exec 语句执行代码对象或字符串形式的python 代码。

    exec obj

    被执行的对象(obj)可以只是原始的字符串,比如单一语句或是语句组,它们也可以预编译成

一个代码对象(分别用'single'和'exec"参数)。

>>> exec """
... x = 0
... print 'x is currently:', x
... while x < 5:
... x += 1
... print 'incrementing x to:', x
... """
x is currently: 0
incrementing x to: 1
incrementing x to: 2
incrementing x to: 3
incrementing x to: 4
incrementing x to: 5

    最后, exec 还可以接受有效的python 文件对象。如果我们用上面的多行代码创建一个叫xcount.py 的文件,那么也可以用下面的方法执行相同的代码

>>> f = open('xcount.py') # open the file
>>> exec f # execute the file
x is currently: 0
incrementing x to: 1
incrementing x to: 2
incrementing x to: 3
incrementing x to: 4
incrementing x to: 5

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • python之exec,eval,exe

    exec语句将字符串str当成有效Python代码来执行.提供给exec的代码的名称空间和exec语句的名称空间相同.exec语句用来执行储存在字符串或文件中的...

    py3study
  • Python重新加载模块方法

    为防止两个模块互相导入的问题,Python默认所有的模块都只导入一次,如果需要重新导入模块, Python2.7可以直接用reload(),Python3可以用...

    py3study
  • OSI第3层:网络层

    4) 解封。(网络层解封该数据包,然后将数据包中包含的第 4 层 PDU 向上传 送到传输层的相应服务。)

    py3study
  • python之exec,eval,exe

    exec语句将字符串str当成有效Python代码来执行.提供给exec的代码的名称空间和exec语句的名称空间相同.exec语句用来执行储存在字符串或文件中的...

    py3study
  • WebService基于SoapHeader实现安全认证

          本文仅提供通过设置SoapHeader来控制非法用户对WebService的调用,如果是WebService建议使用WSE3.0来保护Web服务,如...

    跟着阿笨一起玩NET
  • Java Web之动态代理

    动态代理通俗解释: A接口有c方法,类B实现A接口,原本应该是执行B类中的c方法,可现在不这样做,可以先声明产生B类的代理类B',由它来冒充B类的“兄弟”并“实...

    YungFan
  • Celery的使用

    Celery是一个简单、灵活且可靠的,处理大量消息的分布式系统,专注于实时处理的异步任务队列,同时也支持任务调度,可用于处理实时数据以及任务调度。

    GH
  • 数据库日志中一条"异常"信息所包含的细节(r6笔记第18天)

    今天在梳理服务器的信息的时候,发现有一台服务器没有设置crontab作业,一般的服务器中可能会需要一些定时的任务来触发一些备份,清理等等工作。 因为这是一台备库...

    jeanron100
  • GCAC37 9.9 Case study: an attack on non-atomic decryption in SSH

    9.9 Case study: an attack on non-atomic decryption in SSH

    安包
  • Trello-看板管理

    可以把它理解为一个白板,上面贴满了各种卡片,每个卡片上都记录了一件事项,这些卡牌可以在这个白板上随意的移动和分组,同时它支持多人在这个看板上进行操作。它的设计理...

    用户1428723

扫码关注云+社区

领取腾讯云代金券