python的namespace的理解

Python命名空间的本质

python中的名称空间是名称(标识符)到对象的映射。

具体来说,python为模块、函数、类、对象保存一个字典(__dict__),里面就是重名称到对象的映射。

-------------------------------------------------------------------------------------------

import urllib

import re

x=1 # 变量

def abc(): # 函数

pass

def qq(self): # 方法

pass

class typ(object): # 类

"""docstring for typ"""

def __init__(self, arg):

super(typ, self).__init__()

self.arg = arg

def classqq(self): # 不存在于全局变量中

pass

print(globals().keys()) # 打印字典中的key值

print()

print(globals()) # 打印全局变量,打印出来是以字典的形式展示

-----------------------------------------------------------------------------------------------

dict_keys([‘__name__‘, ‘__doc__‘, ‘__package__‘, ‘__loader__‘, ‘__spec__‘, ‘__annotations__‘, ‘__builtins__‘, ‘__file__‘, ‘__cached__‘, ‘urllib‘, ‘re‘, ‘x‘, ‘abc‘, ‘qq‘, ‘typ‘])

{‘__name__‘: ‘__main__‘, ‘__doc__‘: None, ‘__package__‘: None, ‘__loader__‘: <_frozen_importlib_external.SourceFileLoader object at 0x0000000001DEC048>, ‘__spec__‘: None, ‘__annotations__‘: {}, ‘__builtins__‘: <module ‘builtins‘ (built-in)>, ‘__file__‘: ‘D:\\Learn\\practice\\case1.py‘, ‘__cached__‘: None, ‘urllib‘: <module ‘urllib‘ from ‘D:\\Programs\\Python\\Python36\\lib\\urllib\\__init__.py‘>, ‘re‘: <module ‘re‘ from ‘D:\\Programs\\Python\\Python36\\lib\\re.py‘>, ‘x‘: 1, ‘abc‘: <function abc at 0x00000000001F2E18>, ‘qq‘: <function qq at 0x00000000021FAAE8>, ‘typ‘: <class ‘__main__.typ‘>}

-------------------------------------------------------------------------------------------

x=1 # 变量

def abc(): # 函数

pass

def qq(self): # 方法

pass

class Typ(object): # 类

"""docstring for typ"""

k=1 # 私有变量没有被init初始化

def __init__(self):

super(Typ, self).__init__()

self.y = 2

self.z = 3

def func(self): # 函数方法不存在于全局命名空间中

print("abcd") # 函数方法会默认return None

func.fx = 2

test1 = Typ()

print(Typ.__dict__)

print(test1.__dict__)

print(test1.func.__dict__)

print(globals().keys())

----------------------------------------------------------------------------------------------

{‘__module__‘: ‘__main__‘, ‘__doc__‘: ‘docstring for typ‘, ‘k‘: 1, ‘__init__‘: <function Typ.__init__ at 0x00000000029007B8>, ‘func‘: <function Typ.func at 0x0000000002900840>, ‘__dict__‘: <attribute ‘__dict__‘ of ‘Typ‘ objects>, ‘__weakref__‘: <attribute ‘__weakref__‘ of ‘Typ‘ objects>}

{‘y‘: 2, ‘z‘: 3}

{‘fx‘: 2}

dict_keys([‘__name__‘, ‘__doc__‘, ‘__package__‘, ‘__loader__‘, ‘__spec__‘, ‘__annotations__‘, ‘__builtins__‘, ‘__file__‘, ‘__cached__‘, ‘urllib‘, ‘re‘, ‘x‘, ‘abc‘, ‘qq‘, ‘Typ‘, ‘test1‘])

[Finished in 0.1s]

https://blog.csdn.net/u012436149/article/details/72819539

locals

内置函数locals(), 返回当前函数(方法)的局部命名空间

def function(a=1):

b=2

print(locals())

return a+b

print(function())

-----------------------------

{‘b‘: 2, ‘a‘: 1}

3

globals

内置函数globals(),返回当前module的命名空间

def function(a=1):

b=2

print(locals())

return a+b

print(function())

print(globals().keys())

--------------------------------------

{‘b‘: 2, ‘a‘: 1}

3

dict_keys([‘__name__‘, ‘__doc__‘, ‘__package__‘, ‘__loader__‘, ‘__spec__‘, ‘__annotations__‘, ‘__builtins__‘, ‘__file__‘, ‘__cached__‘, ‘urllib‘, ‘re‘, ‘function‘])

[Finished in 0.1s]

locals()和globals()有一个区别是,locals只读,globals可以写

from module import 和 import module

  • 使用import module时,module本身被引入,但是保存它原有的命名空间,所以我们需要使用module.name这种方式访问它的 函数和变量。
  • from module import这种方式,是将其它模块的函数或者变量引到当前的命名空间中,所以就不需要使用module.name这种方式访问其它的模块的方法了。

原文地址:https://www.cnblogs.com/TomBombadil/p/10979588.html

时间: 2024-07-29 04:26:45

python的namespace的理解的相关文章

【跟我一起学Python吧】python with statement 进阶理解

由于之前有一个项目老是要打开文件,然后用pickle.load(file),再处理...最后要关闭文件,所以觉得有点繁琐,代码也不简洁.所以向python with statement寻求解决方法. 在网上看到一篇文章:http://effbot.org/zone/python-with-statement.htm是介绍with 的,参考着例子进行了理解. 如果经常有这么一些代码段的话,可以用一下几种方法改进: 代码段: set thing up try: do something except

我对python线程池的理解

#!/usr/bin/env pythonfrom Queue import Queuefrom threading import Threadimport randomimport time def person(i,q):    while True:  #这个人一直处与可以接活干的状态        q.get()        print "Thread",i,"do_job"        time.sleep(random.randint(1,5))#每

Python if __name__ == &#39;__main__&#39;: 理解

if __name__ == '__main__':是为了区分.py文件是自己直接被执行还是被其他文件调用. 当.py文件直接被执行时,默认的是 __name__ = '__main__',因此条件成立,将执行if语句中的操作: 当.py文件被其他文件调用时,默认的是 __name__ = 'xxx', (当前文件为xxx.py),因此if语句判断条件不成立,if中的操作不会执行: 但是,这两种情况下,if语句之外的其他语句都将正常按顺序执行,且在if语句执行之前. Python if __na

转发对python装饰器的理解

[Python] 对 Python 装饰器的理解的一些心得分享出来给大家参考 原文  http://blog.csdn.net/sxw3718401/article/details/39519587 主题 Python 最近写一个py脚本来整理电脑中的文档,其中需要检校输入的字符,为了不使代码冗长,想到使用装饰器. 上网搜索有关python的装饰器学习文档,主要看的是 AstralWind的一篇博文,以及Limodou的一篇文章.作为初学者,这两篇文章对新手有很大的帮助,但仍然有些不易理解的地方

Python(os和sys)理解

Python(os和sys)理解 os模块负责程序与操作系统的交互,提供了访问操作系统底层的接口; sys模块负责程序与python解释器的交互,提供了一系列的函数和变量,用于操控python的运行时环境. os与sys模块的官方解释如下: os: This module provides a portable way of using operating system dependent functionality. 这个模块提供了一种方便的使用操作系统函数的方法. sys: This mod

关于Python中的列表理解及用法

在Python中,列表理解通常用于编写单行语句,这些语句通过可迭代对象进行迭代以创建新的列表或字典.本文首先介绍for循环如何在Python中工作,然后解释如何在Python中使用列表理解. Python中的for循环 Python中的for循环语句按顺序遍历任何对象.列表.字符串等的成员.与其他编程语言相比,它的语法更加简洁,不需要手工定义迭代步骤,也不需要开始迭代.尽管有几种方法可以使它的行为与其他编程语言相同(本文将不详细讨论).还可以使用continue.break.pass等语句控制f

Python 装饰器自理解备忘

简单的装饰器代码(给装饰的函数有参数和返回值): #!_*_ coding=utf-8 _*_ #!/usr/bin/env python def outer(fun):     def wrapper(var):         print "装饰前"         resulf = fun(var)         print "装饰后"         return resulf     return wrapper @outer def Func1(var

python 引用和对象理解

今天浏览博客的时候看到这么一句话: python中变量名和对象是分离的:最开始的时候是看到这句话的时候没有反应过来.决定具体搞清楚一下python中变量与对象之间的细节.(其实我感觉应该说 引用和对象分离 更为贴切) 从最开始的变量开始思考: 在python中,如果要使用一个变量,不需要提前进行声明,只需要在用的时候,给这个变量赋值即可 (这个和C语言等静态类型语言不同,和python为动态类型有关). 举第一个栗子: a = 1 这是一个简单的赋值语句,整数 1 为一个对象,a 是一个引用,利

python中HTMLParser简单理解

找一个网页,例如https://www.python.org/events/python-events/,用浏览器查看源码并复制,然后尝试解析一下HTML,输出Python官网发布的会议时间.名称和地点. 1 from html.parser import HTMLParser 2 from html.entities import name2codepoint 3 4 class MyHTMLParser(HTMLParser): 5 6 in_title = False 7 in_loca