从单独的文件烧瓶SQLAlchemy python3访问数据库

时间:2019-06-22 05:46:14

标签: python python-3.x sqlite flask flask-sqlalchemy

我正在编写一个烧瓶应用程序。我有两个文件。 main.py和database.py。我想从database.py文件创建一个数据库。 main.py应该访问database.py文件,并创建名为“ Users”的数据库和表。但是它显示导入错误。帮助我解决这个问题

main.py

from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from databases import User

app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:////tmp/data_log.db'
db = SQLAlchemy(app)

if __name__ == '__main__':
    db.create_all()
    app.run(host='0.0.0.0', port=5001)  

databases.py

from main import db
from passlib.apps import custom_app_context as pwd_context

class User(db.Model) :
    __tablename__ = 'users'
    user_id     =   db.Column(db.Integer, primary_key = True)
    username    =   db.Column(db.String(32), index = True)
    password    =   db.Column(db.String(128))
    def hash_password(self, password) :
        self.password =pwd_context.hash(password)
    def verify_password(self, password) :
        return pwd_context.verify(password, self.password)

跟踪:

Traceback (most recent call last):
  File "main.py", line 3, in <module>
    from databases import User
  File "/home/paulsteven/stack/databases.py", line 1, in <module>
    from main import db
  File "/home/paulsteven/stack/main.py", line 3, in <module>
    from databases import User
ImportError: cannot import name 'User'

1 个答案:

答案 0 :(得分:0)

这是周期性进口冲突的常见情况。 追溯为您提供了清晰的步骤:

操作步骤:

  • 您运行main.py
  • 控制流开始导入要素/库,直到获得第三行 from databases import User
  • 进入databases模块以查找所需的User类。但是... User可能会使用外部作用域功能(并且确实需要db.Model),因此控制流需要从头开始扫描databases模块。这反映了追溯("/home/paulsteven/stack/databases.py", line 1)的第二步
  • 从上一步的位置database.py开始,控制流遇到from main import db- ,这意味着它应返回到main({{1} })模块!
  • 返回到main.py模块的
  • 控制流从第一行开始再次扫描-直到再次找到main 。这反映了回溯的第三步(from databases import User
    • 然后您就陷入循环...

解决问题的正确方法是什么?
将所有数据库上下文/数据库模型放在单独的模块中。
遵循对象关系的顺序以及它们如何相互依赖:

--->首先实例化应用程序(File "/home/paulsteven/stack/main.py", line 3

  • --->然后根据app创建数据库框架实例db = SQLAlchemy(app)

    • --->然后根据app实例创建自定义数据库模型(如User(db.Model)

main.py

db