我正在编写一个烧瓶应用程序。我有两个文件。 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'
答案 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