python
使用命名空间记录变量。python
中的命名空间就像是一个dict
,key
是变量的名字,value
是变量的值。python
python
中,每一个函数都有一个本身的命名空间,叫作local namespace
,它记录了函数的变量。python
中,每一个module
有一个本身的命名空间,叫作global namespace
,它记录了module
的变量,包括 functions, classes
和其它imported modules
,还有 module
级别的 变量和常量。build-in
命名空间,能够被任意模块访问,这个build-in
命名空间中包含了build-in function
和 exceptions
。当python
中的某段代码要访问一个变量x
时,python
会在全部的命名空间中寻找这个变量,查找的顺序为:闭包
namespace
中都找不到变量x
,python
会假设x
是build-in
的函数或者变量。若是x
不是内置函数或者变量,python
会报错NameError
。对于闭包来讲,这里有一点区别,若是在local namespace中找不到变量的话,还会去父函数的local namespace中找变量。函数
内置函数locals()
, 返回当前函数(方法)的局部命名空间ui
def func(a = 1): b = 2 print(locals()) return a+b func() # {'a': 1, 'b': 2} 能够看出,locals返回的是个dict
内置函数globals()
,返回当前module
的命名空间spa
def func(a = 1): b = 2 return a+b func() print(globals()) # globals()返回的也是个dict
locals()和globals()有一个区别是,locals只读,globals能够写code
def func(a = 1): b = 2 return a+b func() glos = globals() glos['new_variable'] = 3 print(new_variable) # 3 , 咱们并无显示定义new_variable这个变量,只是在globals中添加了这个key,在随后的代码中, #就能够像访问通常变量同样来访问。 def func(a = 1): b = 2 locs = locals() locs['c'] = 1 print(c) func() # NameError: name 'c' is not defined
import module
时,module
自己被引入,可是保存它原有的命名空间,因此咱们须要使用module.name
这种方式访问它的 函数和变量。from module import
这种方式,是将其它模块的函数或者变量引到当前的命名空间中,因此就不须要使用module.name
这种方式访问其它的模块的方法了。python
中的module
也是对象,全部的modules
都有一个内置的属性__name__
,模块的__name__
属性的值取决于如何使用这个模块,若是import module
,那么__name__
属性的值是模块的名字。若是直接执行这个模块的话,那么__name__
属性的值就是默认值__main__
。对象