变量根据作用域不同可以分为全局变量和局部变量
1、函数内部的变量没有global声明时,就是一个局部变量,只能在函数内部被使用。
2、全局变量在函数外部声明,作用域为声明之后的代码,如果在声明前被调用,则会报错,如下:
def showglobal():
print(a)
showglobal()
a= "我是全局变量"
print(a)
运行结果:
Traceback (most recent call last):
File "C:/Users/10270/Desktop/py_test/test_10_4.py", line 41, in <module>
showglobal()
File "C:/Users/10270/Desktop/py_test/test_10_4.py", line 37, in showglobal
print(a)
NameError: name 'a' is not defined
全局变量在函数内部也可以被声明,使用global,注意的是,声明时不能够赋值,声明之后才能赋值,声明之后不仅可以在函数内部使用,还能在函数外部使用,如下:
def showglobal():
global a
a = "我是函数内部声明的全局变量"
print(a)
showglobal()
print(a)
运行结果:
我是函数内部声明的全局变量
我是函数内部声明的全局变量
如果在声明之前使用会报错,如下:
def showglobal():
global a
a = "我是函数内部声明的全局变量"
print(a)
print(a)
showglobal()
运行结果:
Traceback (most recent call last):
File "C:/Users/10270/Desktop/py_test/test_10_4.py", line 41, in <module>
print(a)
NameError: name 'a' is not defined
3、变量名称一样声明全局变量和局部变量,使用的时候局部变量的优先级高于全局变量,也就是就近原则。
a = "我是全局变量"
def showglobal():
a = "我是局部变量"
print(a)
print(a)
showglobal()
运行结果:
我是全局变量
我是局部变量
需要注意如下这段代码:
a = 3
def showglobal():
a = a*3
print(a)
print(a)
showglobal()
你以为是不是会输出3和9,代码在执行到showglobal()的时候就报错了:
3
Traceback (most recent call last):
File "C:/Users/10270/Desktop/py_test/test_10_4.py", line 41, in <module>
showglobal()
File "C:/Users/10270/Desktop/py_test/test_10_4.py", line 37, in showglobal
a = a*3
UnboundLocalError: local variable 'a' referenced before assignment
原因就是上面那个就近原则,a = a*3,这里python认为函数内部声明了一个局部变量a ,然后赋值符号右侧就直接拿这个局部变量来进行运算了。而局部变量还没有被赋值。
4、nonlocal声明的变量,一般是在函数嵌套函数内部声明的,声明之后,则可以使用外函数的变量,且可以修改变量的值;
def test():
def test2():
global g_varible
g_varible = '全局变量:global varible'
print("内部函数调用:", g_varible)
def test1():
nonlocal g_varible
g_varible = '内部函数对外部函数局部变量进行了修改:nonlocal '
print("内部函数调用:",g_varible)
test2()
test1()
g_varible = 'global varible'
test()
print( g_varible)
运行结果:
内部函数调用: 全局变量:global varible
内部函数调用: 内部函数对外部函数局部变量进行了修改:nonlocal varible
全局变量:global varible
以上,不管是声明了global还是声明了nonlocal,该变量值修改,都会导致原变量值被修改,它们使用的是同一个引用,也就是使用的是内存中相同地址块的数据.
5、还有一个变量在类中的应用,这个时候就没有局部变量和全局变量的概念了
类中直接定义的变量叫做类属性,属于类,对象可以引用,引用的方法有self.变量名或者直接使用类名.变量名。