База данных SQLite3 с классом db.Models для приложения Flask - PullRequest
0 голосов
/ 02 марта 2020

Я новичок ie в flask, и я учусь после учебника на YouTube https://www.youtube.com/watch?v=CSHx6eCkmv0&t=36s. С 17:25 до 18:40 в разделе учебника мне не удалось создать базу данных, как в этом учебнике. Я попытался использовать терминал, как он, но файл базы данных не появляется после этого. Поскольку я не знаком с использованием терминала, я подозреваю, что, возможно, я не запускаю db.create_all () в правильном каталоге проекта. Как я могу открыть терминал в каталоге проекта, если это проблема? Я также использую Pycharm - есть ли способ создать эту базу данных из Pycharm для следующего кода?

from datetime import datetime
from flask import Flask, render_template, url_for, flash
from flask_sqlalchemy import SQLAlchemy
from werkzeug.utils import redirect


from forms import RegistrationForm, LoginForm

app = Flask(__name__)
app.config['SECRET_KEY'] = '19056ce564a57d892ad4524191d52ee2'
app.config['SQLALCHEMY_DATABASE_URI_'] = 'sqlite:///site.db'
db = SQLAlchemy(app)


class User(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String(20), unique=True, nullable=False)
    email = db.Column(db.String(120), unique=True, nullable=False)
    image_file = db.Column(db.String(20), nullable=False, default='default.jpg')
    password = db.Column(db.String(60), nullable=False)
    posts = db.relationship('Post', backref='author', lazy=True)

    def __repr__(self):
        return f"User('{self.username}', '{self.email}','{self.image_file}')"


class Post(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    title = db.Column(db.String(100), nullable=False)
    date_posted = db.Column(db.DateTime, nullable=False, default=datetime.utcnow)
    content = db.Column(db.Text, nullable=False)
    user_id = db.Column(db.Integer, db.ForeignKey('user.id'), nullable=False)

    def __repr__(self):
        return f"Post('{self.title}', '{self.date_posted}')"


db.create_all()


posts = [
    {'author': 'Corey Schafer',
     'title': 'Blog Post 1',
     'content': 'First post content',
     'date_posted': 'April 20, 2018'
     },
    {'author': 'Jane Doe',
     'title': 'Blog Post 2',
     'content': 'Second post content',
     'date_posted': 'April 21, 2018'
     }
]


@app.route('/')
@app.route('/home')
def home():
    return render_template('home.html', posts=posts)


@app.route('/about')
def about():
    return render_template('about.html', title='About')


@app.route('/register', methods=['GET', 'POST'])
def register():
    form = RegistrationForm()
    if form.validate_on_submit():
        flash(f'Account created for {form.username.data}!', 'success')
        return redirect(url_for('home'))
    return render_template('register.html', title='Register', form=form)


@app.route('/login', methods=['GET', 'POST'])
def login():
    form = LoginForm()
    if form.validate_on_submit():
        if form.email.data == 'admin@blog.com' and form.password.data == 'password':
            flash('You have been logged in!', 'success')
            return redirect(url_for('home'))
        else:
            flash('Login Unsuccessful. Please check username and password', 'danger')
    return render_template('login.html', title='Login', form=form)


if __name__ == '__main__':
    app.run(debug=True)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...