启动我的应用程序时出现此错误。显然,它与SQLAlchemy有关。我一直在Corey Schaffer Flask教程的帮助下处理此示例。
> File "C:\Users\Matea\venv\lib\site-packages\flask\app.py", line 2309, in __call__
return self.wsgi_app(environ, start_response)
File "C:\Users\Matea\venv\lib\site-packages\flask\app.py", line 2295, in wsgi_app
response = self.handle_exception(e)
File "C:\Users\Matea\venv\lib\site-packages\flask\app.py", line 1741, in handle_exception
reraise(exc_type, exc_value, tb)
File "C:\Users\Matea\venv\lib\site-packages\flask\_compat.py", line 35, in reraise
raise value
File "C:\Users\Matea\venv\lib\site-packages\flask\app.py", line 2292, in wsgi_app
response = self.full_dispatch_request()
File "C:\Users\Matea\venv\lib\site-packages\flask\app.py", line 1815, in full_dispatch_request
rv = self.handle_user_exception(e)
File "C:\Users\Matea\venv\lib\site-packages\flask\app.py", line 1718, in handle_user_exception
reraise(exc_type, exc_value, tb)
File "C:\Users\Matea\venv\lib\site-packages\flask\_compat.py", line 35, in reraise
raise value
File "C:\Users\Matea\venv\lib\site-packages\flask\app.py", line 1813, in full_dispatch_request
rv = self.dispatch_request()
File "C:\Users\Matea\venv\lib\site-packages\flask\app.py", line 1799, in dispatch_request
return self.view_functions[rule.endpoint](**req.view_args)
File "C:\Users\Matea\myblog\myblog\main\routes.py", line 11, in home
posts = Post.query.order_by(Post.date_posted.desc()).paginate(page=page, per_page=5)
File "C:\Users\Matea\venv\lib\site-packages\flask_sqlalchemy\__init__.py", line 514, in __get__
return type.query_class(mapper, session=self.sa.session())
File "C:\Users\Matea\venv\lib\site-packages\sqlalchemy\orm\scoping.py", line 74, in __call__
return self.registry()
File "C:\Users\Matea\venv\lib\site-packages\sqlalchemy\util\_collections.py", line 1001, in __call__
return self.registry.setdefault(key, self.createfunc())
File "C:\Users\Matea\venv\lib\site-packages\sqlalchemy\orm\session.py", line 2950, in __call__
return self.class_(**local_kw)
File "C:\Users\Matea\venv\lib\site-packages\flask_sqlalchemy\__init__.py", line 143, in __init__
bind = options.pop('bind', None) or db.engine
File "C:\Users\Matea\venv\lib\site-packages\flask_sqlalchemy\__init__.py", line 877, in engine
return self.get_engine()
File "C:\Users\Matea\venv\lib\site-packages\flask_sqlalchemy\__init__.py", line 896, in get_engine
return connector.get_engine()
File "C:\Users\Matea\venv\lib\site-packages\flask_sqlalchemy\__init__.py", line 556, in get_engine
self._sa.apply_driver_hacks(self._app, info, options)
File "C:\Users\Matea\venv\lib\site-packages\flask_sqlalchemy\__init__.py", line 830, in apply_driver_hacks
if info.drivername.startswith('mysql'):
AttributeError: 'NoneType' object has no attribute 'drivername'
这是一些代码: 这是从我的 init .py
from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from flask_bcrypt import Bcrypt
from flask_login import LoginManager
from flask_mail import Mail
from myblog.config import Config
db = SQLAlchemy()
bcrypt = Bcrypt()
login_manager = LoginManager()
login_manager.login_view = 'users.login'
login_manager.login_message_category = 'info'
mail = Mail()
def create_app(config_class=Config):
app = Flask(__name__)
app.config.from_object(Config)
db.init_app(app)
bcrypt.init_app(app)
login_manager.init_app(app)
mail.init_app(app)
from myblog.users.routes import users
from myblog.posts.routes import posts
from myblog.main.routes import main
from myblog.errors.handlers import errors
app.register_blueprint(users)
app.register_blueprint(posts)
app.register_blueprint(main)
app.register_blueprint(errors)
return app
此段代码来自config.py
import os
class Config:
SECRET_KEY = os.environ.get('SECRET_KEY')
SQLALCHEMY_DATABASE_URI = os.environ.get('SQLALCHEMY_DATABASE_URL')
MAIL_SERVER = 'smtp.googlemail.com'
MAIL_PORT = 587
MAIL_USE_TLS = True
MAIL_USERNAME = os.environ.get('EMAIL_USER')
MAIL_PASSWORD = os.environ.get('EMAIL_PASS')
希望您能帮助我,如果有什么遗漏,请告诉我,谢谢!
答案 0 :(得分:2)
如果已在 .bash_proflie
中正确设置了环境变量 export EMAIL_USER='youremail@gmail.com'
export EMAIL_PASS='Yourpassword'
export SQLALCHEMY_DATABASE_URI='sqlite:///site.db'
export SECRET_KEY='secretkeyxxxxxxxxxxxxxxxx'
然后尝试重新启动计算机。
如果仍然失败
*尝试在python中创建数据库*
from your yourflaskapp import db
db.create_all()
如果您的应用是蓝图
use from yourapp import create_app
app = create_app()
app.app_context().push()
在进行更改后,始终刷新文本编辑器和终端。 另外,请尝试确保您在正确的目录中运行应用。
有关使用蓝图的更多信息,请访问
答案 1 :(得分:1)
@Ivan M,我正在阅读同一教程,并且也遇到了这个问题。发生这种情况是因为讲师将数据库URI和其他参数移到了环境变量中(请参阅第27分钟的Part 11)。这是一种安全措施,也是良好的开发实践。
为了使配置文件能够正常工作,请还原init.py中的更改并更新config.py以使其具有直接链接而不是方括号:
SQLALCHEMY_DATABASE_URI = 'sqlite:///site.db'
UPD:SECRET_KEY
和您希望硬编码的其他参数也是如此:
SECRET_KEY = '5791628bb0b13ce0c676dfde280ba245'
答案 2 :(得分:0)
我按照相同的教程进行操作,并在按照讲师的指导设置 config.py
文件时遇到了这个问题。
我使用的是 PyCharm。 PyCharm 具有设置项目特定 environment variables
的功能。这意味着您可以设置 environment variables
而无需修改 .bash
或 .bash_profile
等文件。
在设置 environment variables
时,我们不应该:
sqlite:///site.db
✅'sqlite:///site.db'
❌SQLALCHEMY_DATABASE_URI
✅'SQLALCHEMY_DATABASE_URI'
❌=
前后的空格注意:如果您通过修改或创建 environment variables
或类似文件来设置 .bash_profile
,上述五点中的一些可能不适用。
我犯了第一个和第二个错误。所以,傻。 ?
Namaste?
答案 3 :(得分:0)
多次遇到这个问题。原因是 Python 无法识别您的 .env
文件。
您可以通过 python-dotenv
安装 pipenv install python-dotenv
。
然后
SQLALCHEMY_DATABASE_URI = os.environ.get('SQLALCHEMY_DATABASE_URL')
会工作。
答案 4 :(得分:0)
我有同样的问题,但 安装 python-dotenv 它解决了问题
pip3 install python3-dotenv
否则,如果没有,则终端建议使用 sudo
尝试以 sudo 为管理员然后它会
安装 env 后即可使用
我再建议一件事......就像如果有人没有设置环境,那么首先在 bashprofile 中为“EMAIL_USER”和“EMAIL_PASS”进行设置,对于那些 SECRET KEY 和 SQLALCHEMY 也是如此
为此,您必须转到 nano 编辑器并制作这些环境
对于 LINUX
nano .bash_profile (enter then it'll take you to the nano editor)
export DB_USER="Your email"
export DB_PASS="Your password"
export SECRET_KEY="your secret key"
export SQLALCHEMY_DATABASE_URI="sqlite:///site.db"
答案 5 :(得分:0)
不确定这是否有帮助。我遇到了同样的问题。 我把 print(f'From init {Config.dict}') 放在 def create_app(config=Config): 在 init.py 的下面,可以看到 config.py 属性从 VS Code bash 终端或独立的 bash 会话 - 一切正常我正在使用 powershell 从 Windows 终端运行 python run.py。从 cmd 运行正常,首先运行 setting.bat 文件