上线前忙忙乎乎写代码,更新了一个同事的代码,发现日志模块报错了
伪代码如下:
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()
输出正常了- -
诶,说到底就是基础不够扎实啊╮(╯_╰)╭