这一章节我们来说说变量名解析的原则:LEGB原则
1.当函数使用未认证的变量名时,python搜索4个作用域,本地作用域(L)->上一层结构中def或者lambda的本地作用域(E)->全局作用域(G)>内置作用域(B),并且在第一次找到这个变量名的地方停下来
2.函数给一个变量赋值的时候,总是创建或者改变本地作用域的变量名,除法他是声明为全局
>>> def test():
x=1
print(x)
print(id(x))
x=2
print(x)
print(id(x))
>>> test()
1
505991632
2
505991648
>>>
在test,我们第一次赋值给x的时候创建了变量,然后后面又改变了变量x,如果x是全局变量时,就会如下:
x='e f t efdad'
def test():
print(x)
print(id(x))
#x=123
#print(x)
#print(id(x))
if __name__=='__main__':
test()
但是,我们需要注意一点,看见上面代码里面的注释没有,如果注释放开了,他就会报错了,为什么?
x='e f t efdad'
def test():
print(x)
print(id(x))
x=123
print(x)
print(id(x))
if __name__=='__main__':
test()
输出:
>>> ================================ RESTART ================================
>>>
Traceback (most recent call last):
File "C:\Python34\test.py", line 9, in
test()
File "C:\Python34\test.py", line 3, in test
print(x)
UnboundLocalError: local variable 'x' referenced before assignment
>>>
没有找到本地变量x,我认为是这样的,虽然py是解释性的语言,但是他还是需要编译成pyc文件来执行,只不过这个过程我们看不见,在编译的过程中x其实已经被认定为本地变量,而不再是模块里面的全局变量,所以才会出现这种情况,那么怎么解决?我们只需要在改动x前面加上global x即可,global关键字我们下面的章节会详细讲述
x='e f t efdad'
def test():
print(x)
print(id(x))
global x
x=123
print(x)
print(id(x))
if __name__=='__main__':
test()
输出:
>>> ================================ RESTART ================================
>>>
e f t efdad
31843176
123
505993584
>>>
上面的代码保存为test.py然后运行即可
3.在函数之外给一个变量赋值(在模块顶层或者idle),本地作用域和模块的命名空间是相同的
总结:这一章节主要简单说明了变量名解析的LEGB原则
这一章节就说到这里,谢谢大家
------------------------------------------------------------------