几个概念:
- python能够改变变量作用域的代码段是def、class、lamda.
- if/elif/else、try/except/finally、for/while 并不能涉及变量作用域的更改,也就是说他们的代码块中的变量,在外部也是可以访问的
- 变量搜索路径是:本地变量->全局变量
- def scopetest():
- localvar=6;
- print(localvar)
- scopetest()
- #print(localvar) #去除注释这里会报错,因为localvar是本地变量
- while True:
- newvar=8
- print(newvar)
- break;
- print(newvar)
- try:
- newlocal=7
- raise Exception
- except:
- print(newlocal)#可以直接使用哦
输出结果:8 8 7
可见这个关键字中定义变量,他们的作用域跟外部是一致的,这个跟Java的作用域概念有点不一样。
- def scopetest():
- var=6;
- print(var)#
- var=5
- print(var)
- scopetest()
- print(var)
输出结果:5 6 5
这里var 首先搜索的是本地变量,scopetest()中 var=6相当于自己定义了一个局部变量,赋值为6. 当然如果的确要修改全局变量的值,则需要如下:
- def scopetest():
- global var
- var=6;
- print(var)#
- var=5
- print(var)
- scopetest()
- print(var)
再看一种这种情况:
- def scopetest():
- var=6;
- print(var)#
- def innerFunc():
- print(var)#look here
- innerFunc()
- var=5
- print(var)
- scopetest()
- print(var)
根据调用顺序反向搜索,先本地变量再全局变量,例如搜先在innerFunc中搜索本地变量,没有,好吧,找找调用关系上一级scopetest,发现本地变量var=6,OK,就用他了。
-------------------------------还有一种情况:
def func():
x = 0
def _func():
x += 1
print x
_func()
if __name__ == "__main__":
func()
此时会报错:
UnboundLocalError: local variable 'x' referenced before assignment
原因是:如果内部函数有引用外部函数的同名变量或者全局变量,并且对这个变量有修改.那么python会认为它是一个局部变量,又因为内部函数_func中没有x的定义,所以报错。
转自:python 变量作用域