Reputation: 303
I have read endless discussions on relative import in python, I think that one of the reasons it is so confusing is that it changes fro one Python version to another (my version is 3.6). But here the culprit seems to be PyCharm (unless i'm mistaken..) and i wonder if anyone came across a solution to this issue. for a project with this layout:
/project
|-- __init__.py
|---subfolder
|-- __init__.py
|-- AA.py
|-- BB.py
Let's imagine that AA.py contains some fuction myfunc
inside the file BB.py
if i write this import:
from AA import myfunc
Then python works perfectly, but PyCharm sees it as an error:
So to make PyCharm happy i can add the .
to the import and then the error is seemingly resolved:
from .AA import myfunc
But then python is not happy, giving me the error: ModuleNotFoundError: No module named '__main__.AA'; '__main__' is not a package
So to conclude, I use the import that actually works (i.e. from AA import myfunc
) but it would be great if i could make PyCharm agree to it somehow because then it offers features such as auto complete, go to definition and so on.
not duplicates: I know it seems like this subject was discussed over and over but it also has many aspects. Here i'm talking about the pycharm aspect and therefore this topic is new as far as i know.
Upvotes: 23
Views: 8219
Reputation: 8610
Mark subfolder
as Source Root with right-click in the project tree -> Mark directory as ... -> Sources Root. PyCharm adds all Source Roots to PYTHONPATH
by default so the issue should be resolved
The problem is PyCharm doesn't know you are going to execute BB.py
directly, e.g. let's say you have main.py
in the root with from subfolder import BB
. Calling python main.py
will raise ModuleNotFoundError: No module named 'AA'
(make sure to use Python 3 to avoid implicit relative imports from Python 2).
Hope it makes sense and I didn't miss anything.
Upvotes: 34
Reputation: 3744
You can get both python and pycharm to agree by using
from subfolder.AA import myfunc
However, according to here, from .AA import myfunc
appears to be the correct syntax. But idk why it's not working.
Upvotes: 4