我目前正在使用Flask Web框架通过Python处理应用程序的用户管理部分,我需要一些帮助来通过SQLAlchemy创建SQLite数据库。
这是我的后端软件包中__init__.py文件的摘录。
from flask_sqlalchemy import SQLAlchemy
from flask import Flask
from flask_bcrypt import Bcrypt
from flask_login import LoginManager
from flask_mail import Mail
from backend.config import Config
db = SQLAlchemy()
bcrypt = Bcrypt()
login_manager = LoginManager()
login_manager.login_view = 'login'
login_manager.login_message_category = 'info'
mail = Mail()
def create_app():
app = Flask(__name__)
app.config.from_object(Config)
db.init_app(app)
bcrypt.init_app(app)
login_manager.init_app(app)
mail.init_app(app)
from backend.users.routes import users
from backend.stats.routes import stats
from backend.queues.routes import queues
app.register_blueprint(users)
app.register_blueprint(stats)
app.register_blueprint(queues)
return app
这是我的主要run.py文件中的摘录。
from backend import create_app
app = create_app()
if __name__ == '__main__':
app.run(host = '127.0.0.1', port = 80, debug = True)
应用程序的配置将SQLALCHEMY_DATABASE_URI称为“ sqlite:///site.db”。
我尝试通过app_context推送应用程序。我已经尝试在其中创建数据库表(坦率地说,我已经尝试了实际上可以在Internet上找到的所有解决方法)。有没有人对我如何解决这个问题有任何建议(除了手动创建表之外,这样做确实可行,但这似乎不是一个长期解决方案)。
快速说明一下,这是我收到的错误。
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "C:\Users\Rachit Bhargava\AppData\Local\Programs\Python\Python37-32\lib\site-packages\flask_sqlalchemy\__init__.py", line 963, in create_all
self._execute_for_all_tables(app, bind, 'create_all')
File "C:\Users\Rachit Bhargava\AppData\Local\Programs\Python\Python37-32\lib\site-packages\flask_sqlalchemy\__init__.py", line 940, in _execute_for_all_tables
app = self.get_app(app)
File "C:\Users\Rachit Bhargava\AppData\Local\Programs\Python\Python37-32\lib\site-packages\flask_sqlalchemy\__init__.py", line 912, in get_app
'No application found. Either work inside a view function or push'
RuntimeError: No application found. Either work inside a view function or push an application context. See http://flask-sqlalchemy.pocoo.org/contexts/.
答案 0 :(得分:0)
您需要向SqlAlchemy构造函数提供应用程序上下文。
from run import app
db = SQLAlchemy(app)