Importations relatives dans Python 3 : percer le mystère
Les importations relatives offrent un moyen pratique d'importer des modules à partir du même répertoire. Cependant, dans certains cas, cela peut conduire aux erreurs suivantes :
Pour comprendre ces erreurs, analysons une structure de répertoires commune :
main.py mypackage/ __init__.py mymodule.py myothermodule.py
Dans ce cas, l'importation relative "from .mymodule import myfunction" dans "myothermodule.py" échouera car "mymodule.py" n'est pas visible dans le chemin de recherche du module. Cela est dû au mécanisme de résolution de module de Python, qui s'appuie sur la variable sys.path.
Une solution consiste à utiliser une importation absolue au lieu d'une importation relative :
from mypackage.mymodule import myfunction
Cela garantit que Python recherche "mymodule" dans le chemin du module "mypackage", qui est supposé se trouver dans sys.path.
Cependant, si vous souhaitez conserver la commodité de importations relatives tout en permettant aux modules d'être exécutés en tant que scripts, considérez ce qui suit :
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
Cette approche permet de retrouver le module dans le système de modules Python plutôt que dans le système de fichiers.
En conclusion, les messages d'erreur rencontrés dans les importations relatives proviennent des mécanismes de résolution de modules de Python. En comprenant le rôle de sys.path et en utilisant différentes stratégies, vous pouvez résoudre ces erreurs et garantir des importations transparentes dans vos applications Python.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!