Python兩個內置函數——locals 和globals
這兩個函數主要提供,基于字典的訪問局部和全局變量的方式。
在理解這兩個函數時,首先來理解一下python中的名字空間概念。Python使用叫做名字空間的東西來記錄變量的軌跡。名字空間只是一個字典,它的鍵字就是變量名,字典的值就是那些變量的值。實際上,名字空間可以象Python的字典一樣進行訪問
每個函數都有著自已的名字空間,叫做局部名字空間,它記錄了函數的變量,包括函數的參數和局部定義的變量。每個模塊擁有它自已的名字空間,叫做全局名字空間,它記錄了模塊的變量,包括函數、類、其它導入的模塊、模塊級的變量和常量。還有就是內置名字空間,任何模
塊均可訪問它,它存放著內置的函數和異常。
當一行代碼要使用變量 x 的值時,Python會到所有可用的名字空間去查找變量,按照如下順序:
1.局部名字空間 - 特指當前函數或類的方法。如果函數定義了一個局部變量 x,Python將使用這個變量,然后停止搜索。
2.全局名字空間 - 特指當前的模塊。如果模塊定義了一個名為 x 的變量,函數或類,Python 將使用這個變量然后停止搜索。
3.內置名字空間 - 對每個模塊都是全局的。作為最后的嘗試,Python將假設 x 是內置函數或變量。
如果Python在這些名字空間找不到 x,它將放棄查找并引發一個 NameError 的異常,同時傳遞
There is no variable named 'x' 這樣一條信息。
象Python中的許多事情一樣,名字空間在運行時直接可以訪問。特別地,局部名字空間可以通過內置的 locals 函數來訪問。全局(模塊級別)名字空間可以通過 globals 函數來訪問
locals 介紹
>>> def test(arg):#函數 foo 在它的局部名字空間中有兩個變量:arg(它的值被傳入函數),和 z(它是在函數里定義的)。 z = 1 print locals()>>> test(4)#locals 返回一個名字/值對的字典。這個字典的鍵字是字符串形式的變量名字,字典的值是變量的實際值。#所以用 4 來調用 foo,會打印出包含函數兩個局部變量的字典:arg (4) 和 z (1)。{'z': 1, 'arg': 4}>>> test('doulaixuexi')#locals 可以用于所有類型的變量。{'z': 1, 'arg': 'doulaixuexi'}>>>globals 介紹
>>> from sys import *>>> print globals(){'setrecursionlimit': <built-in function setrecursionlimit>, 'dont_write_bytecode': False, 'getfilesystemencoding': <built-in function getfilesystemencoding>, 'long_info': sys.long_info(bits_per_digit=15, sizeof_digit=2), 'stdout': <idlelib.rpc.RPCProxy object at 0x02110850>, 'text': <function text at 0x02111A70>, 'meta_path': [], 'exc_clear': <built-in function exc_clear>, 'prefix': 'C://Python27', 'getrefcount': <built-in function getrefcount由此可見,發現globals 函數返回一個全局變量的字典,包括所有導入的變量。
#局部變量函數locals例子(locals 返回一個名字/值對的字典。):
def foo(arg, a): x = 1 y = 'xxxxxx' for i in range(10): j = 1 k = i print locals()#調用函數的打印結果 foo(1,2)#{'a': 2, 'i': 9, 'k': 9, 'j': 1, 'arg': 1, 'y': 'xxxxxx', 'x': 1}
from module import 和 import module之間的不同。使用 import module,模塊自身被導入,
但是它保持著自已的名字空間,這就是為什么你需要使用模塊名來訪問它的函數或屬性(module.function)
的原因。但是使用 from module import,實際上是從另一個模塊中將指定的函數和屬性導入到你自己的名字
空間,這就是為什么你可以直接訪問它們卻不需要引用它們所來源的模塊的原因。
locals 是只讀的,globals 不是
新聞熱點
疑難解答