ImportError: cannot import name ‘db‘ from partially initialized module ‘app‘ (most likely due to a c
前言
最近编写flask项目时,无法加载db,报错
错误信息
C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Scripts\python.exe "D:\pycharm\PyCharm 2020.2.3\plugins\python\helpers\pydev\pydevd.py" --multiproc --qt-support=auto --client 127.0.0.1 --port 51279 --file D:/code/movie_project/manage.py
pydev debugger: process 7596 is connecting
Connected to pydev debugger (build 202.7660.27)
Traceback (most recent call last):
File "<frozen importlib._bootstrap>", line 1007, in _find_and_load
File "<frozen importlib._bootstrap>", line 986, in _find_and_load_unlocked
File "<frozen importlib._bootstrap>", line 680, in _load_unlocked
File "<frozen importlib._bootstrap_external>", line 790, in exec_module
File "<frozen importlib._bootstrap>", line 228, in _call_with_frames_removed
File "D:\code\movie_project\app\__init__.py", line 13, in <module>
from app.admin import admin as admin_blueprint
File "D:\code\movie_project\app\admin\__init__.py", line 7, in <module>
import app.admin.views
File "D:\code\movie_project\app\admin\views.py", line 12, in <module>
from app.admin.forms import LoginForm
File "D:\code\movie_project\app\admin\forms.py", line 12, in <module>
from app.models import Admin
File "D:\code\movie_project\app\models.py", line 11, in <module>
from app import db
ImportError: cannot import name 'db' from partially initialized module 'app' (most likely due to a circular import) (D:\code\movie_project\app\__init__.py)
python-BaseException
Process finished with exit code 1
通过上面人性化的错误信息,可以看到,导入包的顺序不正确,调整包的加载顺序,试一试,调试了导入的顺序,还是不行,最终注释了下面的代码
项目可以跑起来,但是访问接口时爆粗,继续查找错误信息。
C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Scripts\python.exe "D:\pycharm\PyCharm 2020.2.3\plugins\python\helpers\pydev\pydevd.py" --multiproc --qt-support=auto --client 127.0.0.1 --port 51494 --file D:/code/movie_project/manage.py
pydev debugger: process 12068 is connecting
Connected to pydev debugger (build 202.7660.27)
C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\lib\site-packages\flask_sqlalchemy\__init__.py:812: UserWarning: Neither SQLALCHEMY_DATABASE_URI nor SQLALCHEMY_BINDS is set. Defaulting SQLALCHEMY_DATABASE_URI to "sqlite:///:memory:".
warnings.warn(
C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\lib\site-packages\flask_sqlalchemy\__init__.py:833: FSADeprecationWarning: SQLALCHEMY_TRACK_MODIFICATIONS adds significant overhead and will be disabled by default in the future. Set it to True or False to suppress this warning.
warnings.warn(FSADeprecationWarning(
* Restarting with stat
* Serving Flask app "app" (lazy loading)
* Environment: production
WARNING: This is a development server. Do not use it in a production deployment.
Use a production WSGI server instead.
* Debug mode: on
pydev debugger: process 6616 is connecting
C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\lib\site-packages\flask_sqlalchemy\__init__.py:812: UserWarning: Neither SQLALCHEMY_DATABASE_URI nor SQLALCHEMY_BINDS is set. Defaulting SQLALCHEMY_DATABASE_URI to "sqlite:///:memory:".
warnings.warn(
C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\lib\site-packages\flask_sqlalchemy\__init__.py:833: FSADeprecationWarning: SQLALCHEMY_TRACK_MODIFICATIONS adds significant overhead and will be disabled by default in the future. Set it to True or False to suppress this warning.
warnings.warn(FSADeprecationWarning(
* Debugger is active!
* Debugger PIN: 276-680-530
* Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)
127.0.0.1 - - [22/Nov/2020 11:14:58] "GET / HTTP/1.1" 500 -
Traceback (most recent call last):
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\app.py", line 1950, in full_dispatch_request
rv = self.dispatch_request()
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\app.py", line 1926, in dispatch_request
self.raise_routing_exception(req)
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\app.py", line 1908, in raise_routing_exception
raise request.routing_exception
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\ctx.py", line 350, in match_request
result = self.url_adapter.match(return_rule=True)
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\werkzeug\routing.py", line 1945, in match
raise NotFound()
werkzeug.exceptions.NotFound: 404 Not Found: The requested URL was not found on the server. If you entered the URL manually please check your spelling and try again.
During handling of the above exception, another exception occurred:
Traceback (most recent call last):
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\app.py", line 2464, in __call__
return self.wsgi_app(environ, start_response)
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\app.py", line 2450, in wsgi_app
response = self.handle_exception(e)
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\app.py", line 1867, in handle_exception
reraise(exc_type, exc_value, tb)
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\_compat.py", line 39, in reraise
raise value
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\app.py", line 2447, in wsgi_app
response = self.full_dispatch_request()
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\app.py", line 1952, in full_dispatch_request
rv = self.handle_user_exception(e)
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\app.py", line 1816, in handle_user_exception
return self.handle_http_exception(e)
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\app.py", line 1744, in handle_http_exception
return handler(e)
File "D:\code\movie_project\app\__init__.py", line 30, in page_not_found
return render_template('home/404.html'), 404
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\templating.py", line 138, in render_template
ctx.app.jinja_env.get_or_select_template(template_name_or_list),
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\jinja2\environment.py", line 930, in get_or_select_template
return self.get_template(template_name_or_list, parent, globals)
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\jinja2\environment.py", line 883, in get_template
return self._load_template(name, self.make_globals(globals))
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\jinja2\environment.py", line 857, in _load_template
template = self.loader.load(self, name, globals)
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\jinja2\loaders.py", line 115, in load
source, filename, uptodate = self.get_source(environment, name)
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\templating.py", line 60, in get_source
return self._get_source_fast(environment, template)
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\templating.py", line 89, in _get_source_fast
raise TemplateNotFound(template)
jinja2.exceptions.TemplateNotFound: home/404.html
127.0.0.1 - - [22/Nov/2020 11:14:58] "GET /?__debugger__=yes&cmd=resource&f=style.css HTTP/1.1" 200 -
127.0.0.1 - - [22/Nov/2020 11:14:58] "GET /?__debugger__=yes&cmd=resource&f=jquery.js HTTP/1.1" 200 -
127.0.0.1 - - [22/Nov/2020 11:14:58] "GET /?__debugger__=yes&cmd=resource&f=debugger.js HTTP/1.1" 200 -
127.0.0.1 - - [22/Nov/2020 11:14:59] "GET /?__debugger__=yes&cmd=resource&f=ubuntu.ttf HTTP/1.1" 200 -
127.0.0.1 - - [22/Nov/2020 11:14:59] "GET /?__debugger__=yes&cmd=resource&f=console.png HTTP/1.1" 200 -
127.0.0.1 - - [22/Nov/2020 11:15:21] "GET /admin/test HTTP/1.1" 500 -
Traceback (most recent call last):
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\app.py", line 1950, in full_dispatch_request
rv = self.dispatch_request()
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\app.py", line 1926, in dispatch_request
self.raise_routing_exception(req)
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\app.py", line 1908, in raise_routing_exception
raise request.routing_exception
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\ctx.py", line 350, in match_request
result = self.url_adapter.match(return_rule=True)
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\werkzeug\routing.py", line 1945, in match
raise NotFound()
werkzeug.exceptions.NotFound: 404 Not Found: The requested URL was not found on the server. If you entered the URL manually please check your spelling and try again.
During handling of the above exception, another exception occurred:
Traceback (most recent call last):
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\app.py", line 2464, in __call__
return self.wsgi_app(environ, start_response)
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\app.py", line 2450, in wsgi_app
response = self.handle_exception(e)
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\app.py", line 1867, in handle_exception
reraise(exc_type, exc_value, tb)
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\_compat.py", line 39, in reraise
raise value
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\app.py", line 2447, in wsgi_app
response = self.full_dispatch_request()
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\app.py", line 1952, in full_dispatch_request
rv = self.handle_user_exception(e)
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\app.py", line 1816, in handle_user_exception
return self.handle_http_exception(e)
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\app.py", line 1744, in handle_http_exception
return handler(e)
File "D:\code\movie_project\app\__init__.py", line 30, in page_not_found
return render_template('home/404.html'), 404
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\templating.py", line 138, in render_template
ctx.app.jinja_env.get_or_select_template(template_name_or_list),
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\jinja2\environment.py", line 930, in get_or_select_template
return self.get_template(template_name_or_list, parent, globals)
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\jinja2\environment.py", line 883, in get_template
return self._load_template(name, self.make_globals(globals))
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\jinja2\environment.py", line 857, in _load_template
template = self.loader.load(self, name, globals)
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\jinja2\loaders.py", line 115, in load
source, filename, uptodate = self.get_source(environment, name)
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\templating.py", line 60, in get_source
return self._get_source_fast(environment, template)
File "C:\Users\Administrator\.virtualenvs\movie_project-7781sJXo\Lib\site-packages\flask\templating.py", line 89, in _get_source_fast
raise TemplateNotFound(template)
jinja2.exceptions.TemplateNotFound: home/404.html
127.0.0.1 - - [22/Nov/2020 11:15:21] "GET /admin/test?__debugger__=yes&cmd=resource&f=style.css HTTP/1.1" 200 -
127.0.0.1 - - [22/Nov/2020 11:15:21] "GET /admin/test?__debugger__=yes&cmd=resource&f=jquery.js HTTP/1.1" 200 -
127.0.0.1 - - [22/Nov/2020 11:15:21] "GET /admin/test?__debugger__=yes&cmd=resource&f=debugger.js HTTP/1.1" 200 -
127.0.0.1 - - [22/Nov/2020 11:15:21] "GET /admin/test?__debugger__=yes&cmd=resource&f=ubuntu.ttf HTTP/1.1" 200 -
127.0.0.1 - - [22/Nov/2020 11:15:21] "GET /admin/test?__debugger__=yes&cmd=resource&f=console.png HTTP/1.1" 200 -
127.0.0.1 - - [22/Nov/2020 11:15:21] "GET /admin/test?__debugger__=yes&cmd=resource&f=console.png HTTP/1.1" 200 -
感觉是没有导入包:
导入包以后,访问接口可以正常访问:
还没有评论,来说两句吧...