python的exec、eval使用分析

作者:mengwei 时间:2022-05-26 18:38:25 

简介

python 动态执行字符串代码片段(也可以是文件), 一般会用到exec,eval。

exec


exec_stmt ::= "exec" or_expr ["in" expression ["," expression]]

注意:exec 是一个语法声明,不是一个函数.也就是说和if,for一样.

官方文档对于exec的解释


This statement supports dynamic execution of Python code.

exec的第一个表达式可以是:

1.代码字符串
2.文件对象
3.代码对象
4.tuple

前面三种情况差不多,第四种比较特殊最后讲

如果忽略后面的可选表达式,exec后面代码将在当前域执行


>>> a=2
>>> exec "a=1"
>>> a
>>>

如果在表达式之后使用in选项指定一个dic,它将作为global和local变量作用域


>>> a=10
>>> b=20
>>> g={'a':6,'b':8}
>>> exec "global a;print a,b" in g
>>>

如果in后详指定两个表达式,它们将分别用作global和local变量作用域


>>> a=10
>>> b=20
>>> c=20
>>> g={'a':6,'b':8}
>>> l={'b':9,'c':10}
>>> exec "global a;print a,b,c" in g,l
>>>

现在说下tuple的情况,这也是导致很多人误以为exec是一个函数的原因。

如果第一个表达式是tuple


exec(expr, globals) #它等效与 exec expr in globals
exec(expr, globals, locals) #它等效与 exec expr in globals,locals

eval

eval通常用来执行一个字符串表达式,并返回表达式的值。


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

有三个参数,表达式字符串,globals变量作用域,locals变量作用域。 其中第二个和第三个参数是可选的。

如果忽略后面两个参数,则eval在当前作用域执行。


>>> a=1
>>> eval("a+1")
>>>

如果指定globals参数


>>> a=1
>>> g={'a':10}
>>> eval("a+1",g)
>>>

如果指定locals参数


>>> a=10
>>> b=20
>>> c=20
>>> g={'a':6,'b':8}
>>> l={'b':9,'c':10}
>>> eval("a+b+c",g,l)
>>>

如果要严格限制eval执行,可以设置globals为__builtins__,这样 这个表达式只可以访问__builtin__ module。

总结

exec,eval给我带来了极大的灵活性,同时也带来了隐含的危险性, 当我们使用它们的时候应该总是记得详细指定其执行的作用域。

Python中eval带来的潜在风险代码分析

Python验证文件是否可读写代码分享

Python文件操作基本流程代码实例

如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!

来源:http://ju.outofmemory.cn/entry/120085

标签:python,exec,eval
0
投稿

猜你喜欢

  • 浅析Python中的赋值和深浅拷贝

    2021-09-10 14:30:14
  • Python 面向对象编程的三大特性之继承

    2021-08-18 18:19:04
  • 每个分类取最新的几条的SQL实现代码

    2012-08-21 10:57:18
  • Python中unittest用法实例

    2023-09-02 13:13:45
  • Python文件处理与垃圾回收机制详情

    2023-06-14 16:36:17
  • 浅谈Python 对象内存占用

    2022-04-01 11:21:40
  • python环境下安装opencv库的方法

    2022-03-22 10:11:24
  • When we`re only No.2, we try harder之淘宝节日LOGO互动设计小探讨

    2010-01-20 10:31:00
  • Python基于tkinter模块实现的改名小工具示例

    2023-08-31 10:40:01
  • matplotlib共享坐标轴的实现(X或Y坐标轴)

    2023-12-01 23:58:12
  • MySQL优化之数据类型的使用

    2009-03-16 17:12:00
  • java正则表达式匹配所有数字的案例

    2023-07-07 02:59:38
  • 为你的网页添加背景音乐

    2007-02-03 11:39:00
  • python 循环遍历字典元素的简单方法

    2023-12-15 08:06:15
  • asp如何编写一个加法器?

    2009-11-08 18:58:00
  • 在python中list作函数形参,防止被实参修改的实现方法

    2022-11-15 19:27:25
  • Pytest实现setup和teardown的详细使用详解

    2023-09-12 02:06:48
  • 详解python中的异常捕获

    2021-11-21 00:52:20
  • Python Pygame中精灵和碰撞检测详解

    2021-01-31 05:45:27
  • JavaScript缓动动画函数的封装方法

    2023-08-07 10:48:26
  • asp之家 网络编程 m.aspxhome.com