Python globals() locals() vars() 三个内建函数的区别

首先参考官方文档对这三个函数的介绍:

2. Built-in Functions – Python3.5

1、globals()

返回当前全局符号表, 通常是返回当前模块下的全局符号表, 比如全局内建的函数,以及模块里的全局符号(定义声明的变量,类, 实例等), 在函数或者类方法中, globals()返回的模块符号表 是其所在模块, 而不是调用模块.

2、locals()

更新并以字典形式返回当前局部符号表. 自由变量由函数块的locals() 返回, 而不会由 class 块来返回. 需要注意的是, locals() 字典不应该被修改; 在解释器中对修改行为可能对 local 值或者自由变量无效.

3、vars()

返回 __dict__ 属性, 比如模块, 类, 实例, 或者其他 带有 __dict__ 属性的 object. 比如 模块和实例拥有可更新的 __dict__ 属性;然而其他 objects 可能会对 __dict__ 属性的写操作限制(例如 类使用 dictproxy 阻止直接对字典更新).vars() 如果不传参数, 那么作用与 locals() 一样. 需要注意的是, locals 字典只在读操作时使用, 因为对 locals 的更新会被忽略.

4、举例

#!/usr/bin/env python
# -*- coding: utf-8 -*-
#

HELLO = 1

# GLOABLS 字典值包含 __builtins__, __doc__等通用的全局内建函数,模块,
# 以及刚才定义的 HELLO
GLOABLS = globals()
print("outer-global-{}".format(GLOABLS))
LOCALS = locals()  # 此时与 globals() 是等价的!!
print("outer-locals-{}".format(LOCALS))

# globals 和 locals 此时是等价的, GLOBALS 和 LOCALS 其实是指向一个引用
LOCALS[‘B‘] = 1

# VARS 的引用与 GLOABLS LOCALS 一样, 可用 id() 来证实.
VARS = vars()

class A(object):
    # 此时的 locals 是 class 块的 locals, 拥有 A_LOCALS A_GLOBALS 值
    A_LOCALS = locals()

    # 与 GLOBALS 等价
    A_GLOBALS = globals()

    def __init__(self):

        self.func_locals = None
        self.func_globals = None

    def func(self):
        self.func_locals = locals()
        self.func_globals = globals()  # 即 GLOBALS 值

a = A()
a.func()
print("instance-globals-{}".format(a.A_GLOBALS))
print("instance-locals-{}".format(a.A_LOCALS))
a_vars = vars(a)  # 返回实例的 __dict__, 等价于 a_vars = a.__dict__
# print(a_vars)
A_DICT = vars(A)  # 返回类的 dictproxy, 不能对其key直接操作赋值.
print(A_DICT)
a_vars[‘func_vars‘] = "vars"
#print(a.func_vars)  # "vars"
时间: 2024-10-09 10:00:34

Python globals() locals() vars() 三个内建函数的区别的相关文章

Python globals和locals函数_reload函数

Python globals和locals函数_reload函数: globals( ): 返回所有能够访问到的全局名字 num = 5 sum = 0 def add(num): func_sum = 0 func_sum += num return func_sum print(globals()) ''' {'__name__': '__main__', '__doc__': None, '__package__': None, '__loader__': <_frozen_importl

python compile、eval、exec内建函数

compile函数 compile()函数允许程序员在运行时刻迅速生成代码对象,然后就可以用exec 语句或者内建函 数eval()来执行这些对象或者对它们进行求值.一个很重要的观点是:exec 和eval()都可以执行字 符串格式的Python 代码.当执行字符串形式的代码时,每次都必须对这些代码进行字节编译处理. compile()函数提供了一次性字节代码预编译,以后每次调用的时候,都不用编译了. compile(source, filename, mode[, flags[, dont_i

Python 基础【第三篇】输入和输出

这里我们创建一个python(pytest)脚本用于学习测试(以后都为这个文件,不多做解释喽),这个文件必须要有执行权限的哈 1.创建pytest并赋予执行权限 [[email protected]_server py]# touch pytest [[email protected]_server py]# chmod +x pytest 2. 基本输出“print” [[email protected]_server py]# vim pytest #指定python可执行程序路径 #!/u

Python-面向对象(三 元编程)

译注:这是一篇在Stack overflow上很热的帖子.提问者自称已经掌握了有关Python OOP编程中的各种概念,但始终觉得元类(metaclass)难以理解.他知道这肯定和自省有关,但仍然觉得不太明白,希望大家可以给出一些实际的例子和代码片段以帮助理解,以及在什么情况下需要进行元编程.于是e-satis同学给出了神一般的回复,该回复获得了985点的赞同点数,更有人评论说这段回复应该加入到Python的官方文档中去.而e-satis同学本人在Stack Overflow中的声望积分也高达6

visual studio 2015 搭建python开发环境,python入门到精通[三]

在上一篇博客Windows搭建python开发环境,python入门到精通[一]很多园友提到希望使用visual studio 2013/visual studio 2015 python做demo,这里略带一句,其实就"学习python"而言,比较建议使用pycharm,pycharm可以设置VS或者eclipse等多种IDE的编码,可以让绝大部分其他语言使用IDE的习惯者更容易上手.这一点兼容确实做的很好.不过既然这么多园友要求使用vs开发python的话,就介绍一下visual

Python中常见的文件对象内建函数

文件对象内建方法列表 文件对象的方法 操作 file.close() 关闭文件 file.fileno() 返回文件的描述符(file descriptor,FD,整数值) file.flush() 刷新文件的内部缓冲区 file.isatty() 判断file是否是一个类设tty备 file.next() 返回文件的下一行,或在没有其它行时引发StopIteration异常 file.read(size=-1) 从文件读取size个字节,当未给定size或给定负值时读取剩余的所有字节,然后作为

python机器学习实战(三)

python机器学习实战(三) 版权声明:本文为博主原创文章,转载请指明转载地址 www.cnblogs.com/fydeblog/p/7277205.html  前言 这篇博客是关于机器学习中基于概率论的分类方法--朴素贝叶斯,内容包括朴素贝叶斯分类器,垃圾邮件的分类,解析RSS源数据以及用朴素贝叶斯来分析不同地区的态度. 操作系统:ubuntu14.04 运行环境:anaconda-python2.7-jupyter notebook 参考书籍:机器学习实战和源码,机器学习(周志华) not

七日Python之路--第三天

之前由于看基础看的觉着没意思,才去提前看一下Django的.现在突然不知到该干啥了. 不管什么语言,官方文档是必须的.so........... 莫名浮躁,实在看不下去........   待会研究 re 吧.虽然之前研究过,但许久不使用,忘的差不多了....Orz. --2014.7.23 18:37 正则表达式: 1.掌握正则表达式的规则 正则表达式是一种小型,高度专业化的编程语言,内嵌Python中,通过re模块实现. 正则表达式模式被编译成一系列字节码,由用C编写的匹配引擎执行. 字符匹

python实现堆排序的三种方式

# -*- coding: utf-8 -*- """ Created on Fri May 16 14:57:50 2014 @author: lifeix """ import heapq #堆排序 #第一种实现 def Heapify(a, start, end): left = 0 right = 0 maxv = 0 left = start * 2 right = start * 2 + 1 while left <= end: