上线前忙忙乎乎写代码,更新了一个同事的代码,发现日志模块报错了
伪代码如下:
from flask import current_appdef 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 = 10def test(a=None): if a: g = a print gtest()
同样报了UnboundLocalError错误
local variable 'g' referenced before assignment
于是猜出了,在定义这个函数的时候,我们在函数内存在给全局变量 g 赋值的操作,它就默认把函数内的 g 变成了本地变量。(即便这条赋值语句并没有被执行)
所以解决方法是,就是很简单的加个 global 申明全局变量
修改后的代码
g = 10def test(a=None): global g if a: g = a print gtest()
输出正常了- -
诶,说到底就是基础不够扎实啊╮(╯_╰)╭