【Python】变量的作用域

先看下面:

def foo():
    b = 'hello'

    # Python中可以在函数内部再定义函数
    def bar():
        c = True
        print(a)
        print(b)
        print(c)

    bar()
    # print(c)  # NameError: name 'c' is not defined


if __name__ == '__main__':
    a = 100
    # print(b)  # NameError: name 'b' is not defined
    foo()

        上面的代码能够顺利的执行并且打印出 100、hello和True,但我们注意到了,在 `bar`函数的内部并没有定义 `a`和 `b`两个变量,那么 `a`和 `b`是从哪里来的。我们在上面代码的 `if`分支中定义了一个变量 `a`,这是一个全局变量(global variable),属于全局作用域,因为它没有定义在任何一个函数中。在上面的 `foo`函数中我们定义了变量 `b`,这是一个定义在函数中的局部变量(local variable),属于局部作用域,在 `foo`函数的外部并不能访问到它;但对于 `foo`函数内部的 `bar`函数来说,变量 `b`属于嵌套作用域,在 `bar`函数中我们是可以访问到它的。`bar`函数中的变量 `c`属于局部作用域,在 `bar`函数之外是无法访问的。事实上,Python查找一个变量时会按照“局部作用域”、“嵌套作用域”、“全局作用域”和“内置作用域”的顺序进行搜索,前三者我们在上面的代码中已经看到了,所谓的“内置作用域”就是Python内置的那些标识符,我们之前用过的 `input`、`print`、`int`等都属于内置作用域。

        再看看下面这段代码,我们希望通过函数调用修改全局变量 `a`的值,但实际上下面的代码是做不到的。

def foo():
    a = 200
    print(a)  # 200


if __name__ == '__main__':
    a = 100
    foo()
    print(a)  # 100

        在调用 `foo`函数后,我们发现 `a`的值仍然是100,这是因为当我们在函数 `foo`中写 `a = 200`的时候,是重新定义了一个名字为 `a`的局部变量,它跟全局作用域的 `a`并不是同一个变量,因为局部作用域中有了自己的变量 `a`,因此 `foo`函数不再搜索全局作用域中的 `a`。如果我们希望在 `foo`函数中修改全局作用域中的 `a`,代码如下所示。

def foo():
    global a
    a = 200
    print(a)  # 200


if __name__ == '__main__':
    a = 100
    foo()
    print(a)  # 200

        我们可以使用 `global`关键字来指示 `foo`函数中的变量 `a`来自于全局作用域,如果全局作用域中没有 `a`,那么下面一行的代码就会定义变量 `a`并将其置于全局作用域。同理,如果我们希望函数内部的函数能够修改嵌套作用域中的变量,可以使用 `nonlocal`关键字来指示变量来自于嵌套作用域。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值