Python sqlalchemy.exc.OperationalError:(sqlite3.OperationalError)没有这样的表:user。Can';I don’我不能为用户做一张桌子

Python sqlalchemy.exc.OperationalError:(sqlite3.OperationalError)没有这样的表:user。Can';I don’我不能为用户做一张桌子,python,sqlite,flask,sqlalchemy,flask-sqlalchemy,Python,Sqlite,Flask,Sqlalchemy,Flask Sqlalchemy,这是我制作用户表的models.py from datetime import datetime from flaskblog import db, login_manager from flask_login import UserMixin @login_manager.user_loader def load_user(user_id): return User.query.get(int(user_id)) class User(db.Model, UserMixin):

这是我制作用户表的models.py

from datetime import datetime
from flaskblog import db, login_manager
from flask_login import UserMixin


@login_manager.user_loader
def load_user(user_id):
    return User.query.get(int(user_id))


class User(db.Model, UserMixin):
    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)
    posts = db.relationship('PostIntmath', backref='author', lazy=True)
    image_file = db.Column(db.String(20), nullable=False, default='default.jpg')
    password = db.Column(db.String(60), nullable=False)

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


class PostIntmath(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}')"
我看不出有什么不对。 我制作了表格,用于输入用户名和电子邮件

我的routes.py看起来也不错,但每当我尝试登录时,它都会给我一个错误


@app.route("/login", methods=['GET', 'POST'])
def login():
    if current_user.is_authenticated:
        return redirect(url_for('home'))
    form = LoginForm()
    if form.validate_on_submit():
        user = User.query.filter_by(email=form.email.data).first() #error on this line
        if user and bcrypt.check_password_hash(user.password, form.password.data):
            login_user(user, remember=form.remember.data)
            next_page = request.args.get('next')
            return redirect(next_page) if next_page else redirect(url_for('home'))
        else:
            flash('Login Unsuccessful. Please check email and password', 'danger')
    return render_template('login.html', title='Login', form=form)
我得到的错误是:

sqlalchemy.exc.OperationalError: (sqlite3.OperationalError) no such table: user
[SQL: SELECT user.id AS user_id, user.username AS user_username, user.email AS user_email, user.image_file AS user_image_file, user.password AS user_password
FROM user
WHERE user.email = ?
LIMIT ? OFFSET ?]
[parameters: ('abc456@gmail.com', 1, 0)]
(Background on this error at: http://sqlalche.me/e/e3q8)

请帮帮我。我不熟悉烧瓶和SQLAlchemy

请确保检查以下三件事:

1.)使用正确的名称创建表

2.)从模型导入到routes.py的表格

from app.models import User
3.)表名添加到“init”文件或具有shell_content_处理器的文件中。您应该有以下代码

from app import app, db
from app.models import User

@app.shell_context_processor
def make_shell_context():
    return {'db': db, 'User': User}

用你的应用程序名更改应用程序名。

谢谢,但我通过在python模块中执行db.drop\u all()和db.create\u all()修复了我的问题。