【大坑记】Python中的全局变量变成了局部变量

565 查看

上线前忙忙乎乎写代码,更新了一个同事的代码,发现日志模块报错了

伪代码如下:


from flask import current_app

def add_log(data, app=None):
    if app:
        current_app = app
    current_app.game_logger.info(data)

add_log(data)

错误代码:

UnboundLocalError: local variable 'current_app' referenced before assignment

因为确认在flask的app上下文中,而且没有传app参数进去,所以光看代码逻辑,一直很奇怪为啥会报current_app不存在的错误。

后来好奇自己写了个小程序测验

g = 10

def test(a=None):
    if a:
        g = a
    print g

test()

同样报了UnboundLocalError错误

local variable 'g' referenced before assignment

于是猜出了,在定义这个函数的时候,我们在函数内存在给全局变量 g 赋值的操作,它就默认把函数内的 g 变成了本地变量。(即便这条赋值语句并没有被执行)

所以解决方法是,就是很简单的加个 global 申明全局变量

修改后的代码

g = 10

def test(a=None):
    global g
    if a:
        g = a
    print g

test()

输出正常了- -

诶,说到底就是基础不够扎实啊╮(╯_╰)╭