exec()用于执行Python语句如赋值、函数定义等,不返回结果,适合动态执行代码块;而表达式求值应使用eval(),因exec()设计上不返回表达式值,存在安全风险需谨慎使用。
exec() 函数在 Python 中用于动态执行 Python 代码,但它不能直接执行表达式并返回结果。它主要用于执行语句,比如赋值、函数定义、类定义、import 等。
exec() 的基本用法
exec() 接收字符串形式的 Python 代码,并执行它。语法如下:
exec(code, globals, locals)- code:要执行的 Python 代码,可以是字符串、字节对象或 AST 对象
- globals:可选的全局命名空间(字典),控制代码执行时的全局变量范围
- locals:可选的局部命名空间(映射类型),控制局部变量范围
例如,执行一个赋值语句:
code = "x = 10"exec(code)
print(x) # 输出: 10
为什么不能直接执行表达式?
exec() 设计用于执行语句,而不是求值表达式。如果你传入一个纯表达式,比如 "2 + 3",它会执行,但不会返回结果:
result = exec("2 + 3")print(result) # 输出: None
这是因为表达式被执行后没有产生可见副作用,而且 exec() 本身不返回表达式的值。
如何执行表达式并获取结果?
如果想执行表达式并得到返回值,应该使用 eval() 函数:
result = eval("2 + 3")print(result) # 输出: 5
eval() 专门用于求值表达式,而 exec() 用于执行语句。
但在某些情况下,你可以在 exec() 中通过变量捕获表达式的结果:
namespace = {}exec("result = 2 + 3", namespace)
print(namespace["result"]) # 输出: 5
实际应用场景
- 动态定义函数或类
- 运行从文件或网络加载的代码片段
- 实现插件系统或配置脚本
注意:使用 exec() 存在安全风险,不要对不可信来源的代码使用它。
基本上就这些。exec() 适合执行语句,eval() 才是处理表达式的正确选择。两者用途不同,别混用。

求值应使用eval(),因exec()设计上不返回表达式值,存在安全风险需谨慎使用。






