PyCharm resolving - flask.ext.sqlalchemy vs flask_

2019-01-22 19:00发布

问题:

If I use the following format in my application, everything works, except PyCharms resolving / autocomplete feature:

from flask.ext.sqlalchemy import SQLAlchemy

If I use the following format in my application, everything works. But, alas, it is not the correct way to import the libraries:

from flask_sqlalchemy import SQLAlchemy

Is there any way to make PyCharm resolve the first syntax correctly?

回答1:

The flask.ext namespace is a transistion namespace, see the Extension Import Transition section of the Flask Extension Development docs:

For a while we recommended using namespace packages for Flask extensions. This turned out to be problematic in practice because many different competing namespace package systems exist and pip would automatically switch between different systems and this caused a lot of problems for users.

and

Flask extensions should urge users to import from flask.ext.foo instead of flask_foo or flaskext_foo so that extensions can transition to the new package name without affecting users.

So to transition between versions, the flask.ext alias was added, which will automatically try to import flask_[name] packages when importing flask.ext.[name]. But that transition is now moot; you no longer will find packages that still rely solely on flask.ext.

As such, it is perfectly fine to use the actual module name and have PyCharm autocomplete the module contents.

You only really have to use flask.ext if you are still using an older version of the extension and need to be future compatible. That future is already here.



回答2:

FYI. flask.ext is deprecated, and the right way is:

from flask_sqlalchemy import SQLAlchemy

In case anyone found this SO question on Google.



回答3:

Use a virtualenv and set that virtualenv for your project in PyCharm. I had the same problem as you do and after setting the correct virtualenv (which contains the flask and flask_sqlalchemy extension) my problem is solved.

To set a virtualenv for your project in PyCharm (from JetBrains Web Help):

To add an existing virtual environment to the list of available interpreters In the Project Interpreter page of the project settings, click . In the drop-down list, choose Add local.

In the Select Python Interpreter dialog box that opens, choose the desired Python executable, and click OK.

Moreover try adding requirements.txt to the root of your project, afterward PyCharm will notify you to install missing dependencies which might help.