这一章节我们来说说变量名解析的原则: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 est.py", line 9, in <module> test() File "C:Python34 est.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原则
这一章节就说到这里,谢谢大家
------------------------------------------------------------------
版权声明:本文为博主原创文章,未经博主允许不得转载。