python中global和nonlocal用法的详细说明

1.前言

第一,两者的功能不同。global关键字修饰变量后标识该变量是全局变量,对该变量进行修改就是修改全局变量,而nonlocal关键字修饰变量后标识该变量是上一级函数中的局部变量,如果上一级函数中不存在该局部变量,nonlocal位置会发生错误(最上层的函数使用nonlocal修饰变量必定会报错)。

第二,两者使用的范围不同。global关键字可以用在任何地方,包括最上层函数中和嵌套函数中,即使之前未定义该变量,global修饰后也可以直接使用,而nonlocal关键字只能用于嵌套函数中,并且外层函数中定义了相应的局部变量,否则会发生错误(见第一)。

2.global关键字

1.global关键字用来在函数或其他局部作用域中使用全局变量。但是如果不修改全局变量也可以不使用global关键字。

gcount = 0

def global_test():
    gcount+=1
    print (gcount)
global_test()
UnboundLocalError: local variable 'gcount' referenced before assignment

以上代码会报错:第一行定义了全局变量,在内部函数中又对外部函数进行了引用并修改,那么python会认为它是一个局部变量,有因为内部函数没有对其gcount进行定义和赋值,所以报错。

2.如果局部要对全局变量修改,则在局部声明该全局变量。

gcount = 0
 
def global_test():
    global  gcount
    gcount+=1
    print (gcount)
global_test()
1

3.如果局部不声明全局变量,并且不修改全局变量,则可以正常使用。

gcount = 0
 
def global_test():
    print (gcount)
global_test()
0

3. nonlocal关键字

1.nonlocal声明的变量不是局部变量,也不是全局变量,而是外部嵌套函数内的变量。

def make_counter():
    count = 0
    def counter():
        nonlocal count
        count += 1
        return count
    return counter
        
def make_counter_test():
  mc = make_counter()
  print(mc())
  print(mc())
  print(mc())
  
make_counter_test()
1
2
3

4. global和nonlocal混合使用

def scope_test():
    def do_local():
        spam = "local spam" #此函数定义了另外的一个spam字符串变量,并且生命周期只在此函数内。此处的spam和外层的spam是两个变量,如果写出spam = spam + “local spam” 会报错
    def do_nonlocal():
        nonlocal  spam        #使用外层的spam变量
        spam = "nonlocal spam"
    def do_global():
        global spam
        spam = "global spam"
    spam = "test spam"
    do_local()
    print("After local assignmane:", spam)
    do_nonlocal()
    print("After nonlocal assignment:",spam)
    do_global()
    print("After global assignment:",spam)
 
scope_test()
print("In global scope:",spam)
After local assignment: test spam
After nonlocal assignment: nonlocal spam
After global assignment: nonlocal spam
In global scope: global spam

参考

python中global和nonlocal用法的详细说明 https://www.cnblogs.com/yuzhanhong/p/9183161.html

你可能感兴趣的:(python,global,nonlocal,python,关键字)