exec()
是 Python 内置的一个函数,用于在运行时执行动态生成的 Python 代码。它以字符串形式接收一个代码块,并将其编译并执行为可执行的 Python 代码。
exec()
函数的语法如下:
exec(object, globals=None, locals=None)
-
object
:必需,表示要执行的代码块。它可以是以下类型之一:- 字符串:包含要执行的 Python 代码的字符串。
- 代码对象(code object):使用
compile()
函数编译的代码对象。 - 可迭代对象:包含 Python 语句的字符串列表或包含语句的代码对象列表。
-
globals
(可选):一个字典,用于指定全局命名空间的符号表。如果未提供该参数,则使用当前全局符号表。 -
locals
(可选):一个字典,用于指定局部命名空间的符号表。如果未提供该参数,则使用与globals
参数相同的值。
下面是 exec()
函数的使用示例:
# 示例 1: 执行字符串代码块
code = "print('Hello, world!')"
exec(code)
# 示例 2: 指定全局和局部命名空间
globals_dict = {'x': 5}
locals_dict = {}
code = "y = x**2"
exec(code, globals_dict, locals_dict)
print(locals_dict['y']) # 输出: 25
# 示例 3: 执行代码对象
source_code = """
def greet(name):
print(f'Hello, {name}!')
greet('Alice')
"""
code_obj = compile(source_code, "<string>", "exec")
exec(code_obj)
需要注意的是,使用 exec()
函数时要小心潜在的安全风险。由于它可以执行任意代码,因此在接受外部输入或不可信来源的代码时,应谨慎使用,并确保对输入进行适当验证和过滤,以避免代码注入等安全问题。