通过Python Flask创建SQLite数据库时出现“找不到应用程序”错误

时间:2018-11-06 21:45:09

标签: python sqlite flask sqlalchemy flask-sqlalchemy

我目前正在使用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/.

1 个答案:

答案 0 :(得分:0)

您需要向SqlAlchemy构造函数提供应用程序上下文。 from run import app db = SQLAlchemy(app)