gpt4 book ai didi

python - 在蓝图应用程序中访问 Flask 全局变量

转载 作者:太空宇宙 更新时间:2023-11-03 14:45:05 26 4
gpt4 key购买 nike

我的源代码有这样的结构:

main.py:

from flask import Flask, g
app = Flask(__name__)
with app.app_context():
g.my_db = PostgreSQL()
app.register_blueprint(my_app, url_prefix="/my_app")

my_app.py:

from flask import Blueprint, g
my_app = Blueprint("my_app", __name__)
@my_app.route("/")
def index():
return g.my_db.fetch_all() <<< ERROR

但它显示此错误:

AttributeError: '_AppCtxGlobals' 对象没有属性 'my_db'

即使我尝试在应用上下文之外使用 g,它也会显示此错误:

RuntimeError:在应用程序上下文之外工作。

那么如何在Flask中设置和访问全局变量呢?

最佳答案

发生这种情况是因为上下文(with app.app_context())结束时数据丢失了 (doc) .

在上下文中,一切正常:

from flask import Flask, g
app = Flask(__name__)
with app.app_context():
g.my_db = 'database ok'
print(g.my_db)

# >>> this prints 'database ok'

但在外部,您无法访问该属性:

from flask import Flask, g
app = Flask(__name__)
with app.app_context():
g.my_db = 'database ok'

print(g.my_db)

# >>> this throws RuntimeError: Working outside of application context

即使你创建了一个新的上下文:

from flask import Flask, g
app = Flask(__name__)
with app.app_context():
g.my_db = 'database ok'

with app.app_context():
print(g.my_db)

>>> this throws AttributeError: '_AppCtxGlobals' object has no attribute 'my_db'

您最好的做法是在上下文之前声明数据库对象,然后导入它。或者您可以直接在 my_app.py 中您需要的地方创建它?

关于python - 在蓝图应用程序中访问 Flask 全局变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50233118/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com