17370845950

python exec函数怎么用
exec函数用于动态执行Python代码,可运行字符串或编译后的code object,通过globals和locals参数控制作用域以避免污染全局环境;例如exec("a=10\nb=20\nprint(a+b)")输出30,并创建变量a、b;配合compile使用可提升重复执行效率,但需警惕安全风险,禁止对不可信输入使用。

exec 函数是 Python 中用来动态执行 Python 代码的内置函数。它可以把字符串形式的代码、或编译过的代码对象(code object)运行起来,适用于需要在程序运行时动态生成并执行代码的场景。

基本语法

exec(object, globals=None, locals=None)
  • object:要执行的代码,可以是字符串或 code object(通过 compile() 编译得到)
  • globals:可选,全局命名空间(字典),控制代码执行时的全局变量范围
  • locals:可选,局部命名空间(通常也是字典),控制局部变量作用域

exec 执行后没有返回值(返回 None),但会直接产生副作用,比如定义变量、调用函数等。

执行字符串代码

最简单的用法是传入一段 Python 代码字符串:

exec("a = 10\nb = 20\nprint(a + b)")

这段代码会输出 30,并在当前作用域中创建变量 a 和 b。

控制作用域

你可以通过指定 globals 和 locals 参数来限制代码的执行环境:

global_dict = {'x': 5} local_dict = {} exec("y = x * 2", global_dict, local_dict) print(local_dict['y']) # 输出 10

这样可以避免污染全局命名空间,适合执行不受信任的代码片段。

配合 compile 使用

如果你需要多次执行同一段代码,可以先用 compile 编译成 code object,提升效率:

code = compile("for i in range(3): print('Hello', i)", "", "exec") exec(code)

输出:

Hello 0
Hello 1
Hello 2

注意事项

  • 不要对不可信的输入使用 exec,有严重的安全风险
  • exec 不能访问闭包变量(nonlocal 变量),除非显式传入作用域
  • exec 执行的代码中定义的函数、类也会生效

基本上就这些。exec 强大但危险,用的时候要清楚自己在做什么。