Relative Importe in Python 3: Das Geheimnis lüften
Relative Importe bieten eine bequeme Möglichkeit, Module aus demselben Verzeichnis zu importieren. In bestimmten Fällen kann es jedoch zu folgenden Fehlern kommen:
Um diese Fehler zu verstehen, analysieren wir sie eine gemeinsame Verzeichnisstruktur:
main.py mypackage/ __init__.py mymodule.py myothermodule.py
In diesem Fall der relative Import „from .mymodule import myfunction“ innerhalb „myothermodule.py“ schlägt fehl, da „mymodule.py“ im Modulsuchpfad nicht sichtbar ist. Dies liegt am Modulauflösungsmechanismus von Python, der auf der Variablen sys.path basiert.
Eine Lösung besteht darin, einen absoluten Import anstelle eines relativen zu verwenden:
from mypackage.mymodule import myfunction
Dadurch wird sichergestellt Python sucht im Modulpfad „mypackage“ nach „mymodule“, von dem angenommen wird, dass er sich in sys.path befindet.
Wenn Sie jedoch die Bequemlichkeit von beibehalten möchten Beachten Sie bei relativen Importen Folgendes, während Sie zulassen, dass Module als Skripte ausgeführt werden:
import sys import os SCRIPT_DIR = os.path.dirname(os.path.abspath(__file__)) sys.path.append(os.path.dirname(SCRIPT_DIR)) from mypackage.mymodule import myfunction
python3 -m mypackage.myothermodule
Dieser Ansatz ermöglicht, dass das Modul im Python-Modulsystem und nicht im Dateisystem gefunden wird.
Zusammenfassend sind die Fehlermeldungen aufgeführt, die in aufgetreten sind relative Importe ergeben sich aus den Modulauflösungsmechanismen von Python. Indem Sie die Rolle von sys.path verstehen und verschiedene Strategien anwenden, können Sie diese Fehler beheben und nahtlose Importe in Ihre Python-Anwendungen sicherstellen.
Das obige ist der detaillierte Inhalt vonWarum erhalte ich „ImportError', wenn ich relative Importe in Python 3 verwende?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!