flask security ImportError:无法导入名称';db';

flask security ImportError:无法导入名称';db';,flask,flask-security,Flask,Flask Security,我知道这可能是一个循环导入错误,但我无法找到解决方案。到目前为止,这个应用程序非常普通。这是添加了models.py的flask安全教程。这是在准备为项目添加蓝图 从应用程序导入数据库 ImportError:无法导入名称“db” config.py run.py ---app ------__init__py ------models.py run.py from app import app if __name__ == "__main__": app.run() init.p

我知道这可能是一个循环导入错误,但我无法找到解决方案。到目前为止,这个应用程序非常普通。这是添加了models.py的flask安全教程。这是在准备为项目添加蓝图

从应用程序导入数据库 ImportError:无法导入名称“db”

config.py
run.py
---app
------__init__py
------models.py
run.py

from app import app

if __name__ == "__main__":
    app.run()
init.py

from config import Config
import app.models

from flask import Flask, render_template
from flask_sqlalchemy import SQLAlchemy
from flask_security import Security, SQLAlchemyUserDatastore, \
    login_required

db = SQLAlchemy()

# Create app
def create_app():
    app = Flask(__name__)
    app.config.from_object(Config)
    app.config['DEBUG'] = True
    db.init_app(app)

    user_datastore = SQLAlchemyUserDatastore(db, models.Users,
                                             models.usersRoleNames)
    security = Security(app, user_datastore)

    return app

# Views
@app.route('/')
@login_required
def home():
    return render_template('index.html')
models.py

from app import db
from flask_security import UserMixin, RoleMixin

users_roles = db.Table('users_roles',
        db.Column('user_id', db.Integer(), db.ForeignKey('users.id')),
        db.Column('role_id', db.Integer(), db.ForeignKey('users_role_names.id')))


class usersRoleNames(db.Model, RoleMixin):
    id = db.Column(db.Integer(), primary_key=True)
    name = db.Column(db.String(80), unique=True)
    description = db.Column(db.String(255))


class Users(db.Model, UserMixin):
    id = db.Column(db.Integer, primary_key=True)
    email = db.Column(db.String(255), unique=True)
    username = db.Column(db.String(255))
    password = db.Column(db.String(255))
    last_login_at = db.Column(db.DateTime())
    current_login_at = db.Column(db.DateTime())
    last_login_ip = db.Column(db.String(100))
    current_login_ip = db.Column(db.String(100))
    login_count = db.Column(db.Integer)
    active = db.Column(db.Boolean())
    confirmed_at = db.Column(db.DateTime())
    roles = db.relationship('usersRoleNames', secondary=users_roles,
                            backref=db.backref('users',
                                               lazy='dynamic'))

尝试在
models.py
中声明您的
db
对象,并将其导入
app/\uuu init\uuuu.py

from ._db import db
from .tickets import Tickets
from .users import Users, users_roles, usersRoleNames

'''
Below part is optional 
but I like to do it anyways
'''

__all__ = [
    'db',
    'Tickets',
    'Users',
    'users_roles',
    'usersRoleNames',
]

型号.py

from flask_sqlalchemy import SQLAlchemy                                         

db = SQLAlchemy()
...
def create_app():                                                               
    app = Flask(__name__)                                                       
    app.config.from_object(Config)                                              
    app.config['DEBUG'] = True                                                  

    from app.models import db, Users, usersRoleNames                            
    db.init_app(app)                                                                                                             

    user_datastore = SQLAlchemyUserDatastore(db, Users,                         
                                             usersRoleNames)                    
    security = Security(app, user_datastore)                                    

    return app 
app/\uuuu init\uuuuu.py

from flask_sqlalchemy import SQLAlchemy                                         

db = SQLAlchemy()
...
def create_app():                                                               
    app = Flask(__name__)                                                       
    app.config.from_object(Config)                                              
    app.config['DEBUG'] = True                                                  

    from app.models import db, Users, usersRoleNames                            
    db.init_app(app)                                                                                                             

    user_datastore = SQLAlchemyUserDatastore(db, Users,                         
                                             usersRoleNames)                    
    security = Security(app, user_datastore)                                    

    return app 

尝试在
models.py
中声明您的
db
对象,并将其导入
app/\uuu init\uuuu.py

from ._db import db
from .tickets import Tickets
from .users import Users, users_roles, usersRoleNames

'''
Below part is optional 
but I like to do it anyways
'''

__all__ = [
    'db',
    'Tickets',
    'Users',
    'users_roles',
    'usersRoleNames',
]

型号.py

from flask_sqlalchemy import SQLAlchemy                                         

db = SQLAlchemy()
...
def create_app():                                                               
    app = Flask(__name__)                                                       
    app.config.from_object(Config)                                              
    app.config['DEBUG'] = True                                                  

    from app.models import db, Users, usersRoleNames                            
    db.init_app(app)                                                                                                             

    user_datastore = SQLAlchemyUserDatastore(db, Users,                         
                                             usersRoleNames)                    
    security = Security(app, user_datastore)                                    

    return app 
app/\uuuu init\uuuuu.py

from flask_sqlalchemy import SQLAlchemy                                         

db = SQLAlchemy()
...
def create_app():                                                               
    app = Flask(__name__)                                                       
    app.config.from_object(Config)                                              
    app.config['DEBUG'] = True                                                  

    from app.models import db, Users, usersRoleNames                            
    db.init_app(app)                                                                                                             

    user_datastore = SQLAlchemyUserDatastore(db, Users,                         
                                             usersRoleNames)                    
    security = Security(app, user_datastore)                                    

    return app 

我已经找到了一个简单的解决方案,可以使用flask安全性解决循环导入问题。当模型跨不同文件声明时,此解决方案特别有用


1.创建名为
models
的文件夹: 我们所有的模型都将保存在此文件夹中

示例文件夹结构可能如下所示

models/
├── _db.py
├── __init__.py
├── tickets.py
└── users.py

0 directories, 4 files
2.创建名为
\u db.py的文件
: 在此文件中声明
db
对象

文件名可以是任何名称,但以下划线开头的文件名可确保在对导入语句排序时始终首先导入
db
对象

('VS代码提供了自动排序导入的选项,因此使用该选项不会导致任何问题。“)

\u db.py

from flask_sqlalchemy import SQLAlchemy

db = SQLAlchemy()

from ._db import db
from flask_security import RoleMixin, UserMixin

users_roles = db.Table(
    # Table definition
)

class usersRoleNames(db.Model, RoleMixin):
    # Table definition
    ...

class Users(db.Model, UserMixin):
    # Table definition
    ...
3.从
\u db.py
文件导入
db
对象: 现在,我们可以从上面创建的
\u db.py
文件导入
db
对象:

users.py

from flask_sqlalchemy import SQLAlchemy

db = SQLAlchemy()

from ._db import db
from flask_security import RoleMixin, UserMixin

users_roles = db.Table(
    # Table definition
)

class usersRoleNames(db.Model, RoleMixin):
    # Table definition
    ...

class Users(db.Model, UserMixin):
    # Table definition
    ...
4.导入
\uuuu init\uuuuu.py
文件中的所有内容(可选): 创建一个init.py文件,并导入其中的所有模型和
db
对象

\uuuu init\uuuuu.py

from ._db import db
from .tickets import Tickets
from .users import Users, users_roles, usersRoleNames

'''
Below part is optional 
but I like to do it anyways
'''

__all__ = [
    'db',
    'Tickets',
    'Users',
    'users_roles',
    'usersRoleNames',
]

通过导入
\uuuu init\uuuu.py
文件中的所有内容,我们可以直接从models文件夹导入

所以我们可以

from .models import db, Tickets, Users
而不是这个

from .models._db import _db
from .models.tickets import Tickets
from .models.users import Users

只是一个想法:我不确定以“下划线”开头python文件名是否是一种不好的做法。如果您有意见,请分享您的想法。

我找到了一个简单的解决方案,可以解决flask安全性的循环导入问题。当模型跨不同文件声明时,此解决方案特别有用


1.创建名为
models
的文件夹: 我们所有的模型都将保存在此文件夹中

示例文件夹结构可能如下所示

models/
├── _db.py
├── __init__.py
├── tickets.py
└── users.py

0 directories, 4 files
2.创建名为
\u db.py的文件
: 在此文件中声明
db
对象

文件名可以是任何名称,但以下划线开头的文件名可确保在对导入语句排序时始终首先导入
db
对象

('VS代码提供了自动排序导入的选项,因此使用该选项不会导致任何问题。“)

\u db.py

from flask_sqlalchemy import SQLAlchemy

db = SQLAlchemy()

from ._db import db
from flask_security import RoleMixin, UserMixin

users_roles = db.Table(
    # Table definition
)

class usersRoleNames(db.Model, RoleMixin):
    # Table definition
    ...

class Users(db.Model, UserMixin):
    # Table definition
    ...
3.从
\u db.py
文件导入
db
对象: 现在,我们可以从上面创建的
\u db.py
文件导入
db
对象:

users.py

from flask_sqlalchemy import SQLAlchemy

db = SQLAlchemy()

from ._db import db
from flask_security import RoleMixin, UserMixin

users_roles = db.Table(
    # Table definition
)

class usersRoleNames(db.Model, RoleMixin):
    # Table definition
    ...

class Users(db.Model, UserMixin):
    # Table definition
    ...
4.导入
\uuuu init\uuuuu.py
文件中的所有内容(可选): 创建一个init.py文件,并导入其中的所有模型和
db
对象

\uuuu init\uuuuu.py

from ._db import db
from .tickets import Tickets
from .users import Users, users_roles, usersRoleNames

'''
Below part is optional 
but I like to do it anyways
'''

__all__ = [
    'db',
    'Tickets',
    'Users',
    'users_roles',
    'usersRoleNames',
]

通过导入
\uuuu init\uuuu.py
文件中的所有内容,我们可以直接从models文件夹导入

所以我们可以

from .models import db, Tickets, Users
而不是这个

from .models._db import _db
from .models.tickets import Tickets
from .models.users import Users

只是一个想法:我不确定以“下划线”开头python文件名是否是一种不好的做法。如果你有意见,请分享你的想法。

它解决了一个问题,又制造了另一个问题。谢谢你的建议。让我来解决这个问题,我会标记它的解决。users\u roles=db.Table('users\u roles',AttributeError:type对象'SQLAlchemy'没有属性'Table'。它修复了一个问题,并创建了另一个问题。感谢您的建议。让我解决这部分问题,并将其标记为已解决。users\u roles=db.Table('users_roles',AttributeError:type对象'SQLAlchemy'没有属性'Table'。感谢您的回复和发布。我不再使用flask security,因此无法测试此功能。此项目已迁移到Vue.js(Nuxt)作为一个独立的客户端/前端和一个flask独立/后端。但是,网站安全性已经完全重新编写。我想这对其他人会有帮助。很高兴我能提供帮助。感谢您的回复和发布。我不再使用flask安全性,所以我没有能力测试它。此项目已迁移将Vue.js(Nuxt)作为一个独立客户端/前端和一个flask独立/后端。但是,站点安全性已经完全重写。我想这会对其他人有所帮助。很高兴我能提供帮助。