Flask 中的导入错误- sqlalchemy - 无法从“app”导入名称“Post”

问题描述 投票:0回答:0

我正在观看使用 Sqlite 和 sqlalchemy 的烧瓶应用程序的视频教程。 我是第一次尝试这个。 以下是创建 db User 和 Post 类(或表)的“app.py”文件的代码。

from flask import Flask, render_template, url_for, flash, redirect
from flask_sqlalchemy import SQLAlchemy
from forms import RegistrationForm, LoginForm
from datetime import datetime

app = Flask(__name__)
app.config['SECRET_KEY'] = '5ef9e49a4ece37050f2aefeea1a965c3'
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), unique =True, 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}')"```

然后运行以下命令-

from app import app,db
app.app_context().push()
db.create_all()

然后为了将 User 和 Post 表加载到数据库中,运行以下命令 -

from app import User, Post

这给出了一个错误 - from app import User, Post 追溯(最近一次通话): 文件“”,第 1 行,位于 ImportError:无法从“app”导入名称“Post”

代码没有显示错误,但是导入命令给出了上述错误。 请帮忙!

sqlite flask flask-sqlalchemy
© www.soinside.com 2019 - 2024. All rights reserved.