Как определить и получить доступ к базе данных postgresql, как пример кода фляги - PullRequest
0 голосов
/ 29 мая 2019

Я использую python flask, я хочу подключиться к postgresql, используйте код, подобный образцу flask, в по этой ссылке , но в примере кода используйте sqlite3.Я пытаюсь найти пример кода и сбить меня с толку, потому что каждый пример использует свой подход.Этот код выполняется, но при использовании CLI для инициализации ошибки базы данных.

Error: No such command "init-db".

Мой структурный файл

enter image description here

Это мой код:

run.py

#run.py
import os

from smart_app import create_app

app = create_app()

if __name__ == '__main__':
    app.run()

init .py

#__init__.py
from flask import Flask


def create_app(config_filename=None):
    app = Flask(__name__, instance_relative_config=True)

    # load default configuration
    app.config.from_object('config.default')

    # load the configuration from the instance folder
    app.config.from_pyfile('config.py')

    # Load the file specified by the APP_CONFIG_FILE environment variable
    # Variables defined here will override those in the default configuration
    app.config.from_envvar('APP_CONFIG_FILE')

    # Connect to database
    from . import db
    db.init_app(app)


    return app

db.py

db.py

импорт клик из колбы импорт current_app, g из flask.cli импорт with_appcontext из flask_sqlalchemy импорт SQLAlchemy

# db = SQLAlchemy()

def get_db():
    if 'db' not in g:
        g.db = SQLAlchemy()

    return g.db

def close_db(e=None):
    db = g.pop('db', None)

    if db is not None:
        db.close()

def init_db():
    db = get_db()

    with current_app.open_resource('schema.sql') as f:
        db.executescript(f.read().decode('utf8'))

@click.command('init-db')
@with_appcontext
def init_db_command():
    """Clear the existing data and create new tables."""
    init_db()
    click.echo('Initialized the database')

def init_app(app):
    app.teardown_appcontext(close_db)
    app.cli.add_command(init_db_command)

1 Ответ

1 голос
/ 29 мая 2019

Если вы знакомы с SQL, используйте psycopg2 для подключения к вашей базе данных postgresql.
Или, если вы хотите использовать ORM для работы с базой данных в колбе, вы можете использовать flask_sqlalchemy.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...