Python 的内置函数 globals
Python 内建函数列表 > Python 的内置函数 globals
Python 的内置函数 globals()
是一个非常重要的工具函数,它返回一个字典,表示当前全局符号表。这个字典包含了当前模块中定义的所有全局变量、函数和类的名称及其对应的值。
def globals():'''返回实现当前模块命名空间的字典:return: 当前模块命名空间的字典'''
具体来说:
- 返回值是一个字典对象
- 字典的键是变量名或函数名(字符串形式)
- 字典的值是对应的对象引用
- 修改这个字典会直接影响全局命名空间
典型应用场景包括:
- 动态访问或修改全局变量
- 调试时查看当前全局状态
- 框架开发中实现动态功能
示例用法:
x = 10
y = "hello"def func():pass# 获取全局变量字典
g = globals()# 访问全局变量
print(g["x"]) # 输出: 10
print(g["y"]) # 输出: "hello"# 修改全局变量
g["x"] = 20
print(x) # 输出: 20# 添加新全局变量
g["z"] = [1, 2, 3]
print(z) # 输出: [1, 2, 3]
注意事项:
- 在函数内部使用时,
globals()
仍然返回模块级的全局变量,而不是函数的局部变量。例如:
x = 10 # 全局变量
def test():y = 20 # 局部变量print(globals()) # 输出包含x但不包含y
test()
这个特性与 local()
形成鲜明对比,后者在函数内部调用时会返回函数的局部命名空间。
- 与
locals()
不同,globals()
的一个重要特点是它的行为具有一致性:无论在任何位置调用(模块级、函数内部、类方法中等),它都返回相同的结果 - 即当前模块的全局命名空间。例如:
def outer():def inner():print(globals()) # 与模块级调用结果相同inner()
outer()
这种可预测的行为使得 globals()
比 locals()
更适合在嵌套环境中使用。
- 虽然
globals()
提供了便利的全局变量访问方式,但过度使用可能会使代码变得难以维护:
- 它会破坏代码的封装性,使得函数不再自包含
- 可能导致难以追踪的变量修改
- 增加代码的耦合度
建议仅在以下场景谨慎使用:
# 合理的使用示例:动态配置
CONFIG = {'debug': True}def process_data():if globals().get('CONFIG', {}).get('debug'):print("Debug mode enabled")
在其他情况下,更推荐使用显式的参数传递或类属性访问。
在框架开发中,globals()
常用于实现插件系统或动态加载功能,允许在运行时注册新的全局对象。