Я зрозумів це. Дуже засмучує, особливо йде від python2.
Ви повинні додати .
до модуля незалежно від того, відносний він чи абсолютний.
Я створив налаштування каталогу наступним чином.
/main.py
--/lib
--/__init__.py
--/mody.py
--/modx.py
modx.py
def does_something():
return "I gave you this string."
mody.py
from modx import does_something
def loaded():
string = does_something()
print(string)
main.py
from lib import mody
mody.loaded()
коли я виконую головне, саме так і відбувається
$ python main.py
Traceback (most recent call last):
File "main.py", line 2, in <module>
from lib import mody
File "/mnt/c/Users/Austin/Dropbox/Source/Python/virtualenviron/mock/package/lib/mody.py", line 1, in <module>
from modx import does_something
ImportError: No module named 'modx'
Я запустив 2to3, і основний вихід був таким
RefactoringTool: Refactored lib/mody.py
--- lib/mody.py (original)
+++ lib/mody.py (refactored)
@@ -1,4 +1,4 @@
-from modx import does_something
+from .modx import does_something
def loaded():
string = does_something()
RefactoringTool: Files that need to be modified:
RefactoringTool: lib/modx.py
RefactoringTool: lib/mody.py
Мені довелося змінити імпорт імпорту mody.py, щоб виправити його
try:
from modx import does_something
except ImportError:
from .modx import does_something
def loaded():
string = does_something()
print(string)
Потім я знову запустив main.py і отримав очікуваний результат
$ python main.py
I gave you this string.
Нарешті, просто очистити його та зробити його портативним між 2 та 3.
from __future__ import absolute_import
from .modx import does_something