Heim > Artikel > Backend-Entwicklung > Lösung für die doppelten Namen von Python-Modulen und -Paketen
Dieser Artikel führt Sie hauptsächlich in die Methode zum Umgang mit Modulen und Paketen mit demselben Namen in Python ein. Die Einführung im Artikel ist sehr detailliert und bietet einen gewissen Referenz- und Lernwert für alle Freunde, die sie benötigen .
Vorwort
In der ProgrammierungEntwicklung habe ich persönlich das Gefühl, dass es so sein wird, solange man sich an die Spezifikationen hält wenige Probleme. Wenn Sie mit dem Erlernen einer Technologie beginnen, werden Sie in der Tat auf viele Fallstricke stoßen. Es ist gut, dass Sie auf weitere Fallstricke gestoßen sind. Sie werden mehr und mehr erfahren, wie wichtig es ist, die Regeln zu befolgen. Manchmal sollte man wirklich auf den Rat erfahrener Menschen hören und nicht seinen eigenen Weg gehen. Dies scheint nicht der Schwerpunkt dieses Artikels zu sein. Tatsächlich möchte ich zum Ausdruck bringen, dass wir unser Bestes geben sollten, um die Dinge gemäß den Standards zu erledigen, damit wir viele Umwege vermeiden.
Die wichtigste Programmiersprache, die ich jetzt verwende, ist Python. Bisher habe ich das Gefühl, dass ich auf sehr wenige Fallstricke gestoßen bin, seit ich mit Python in Berührung gekommen bin, und im Grunde bin ich auf keine seltsamen Probleme gestoßen Probleme. Tatsächlich ist dies keine gute Sache. Wenn Sie nicht in die Falle tappen, werden Sie viele im Dunkeln liegende Wissenspunkte nicht verstehen, sodass es schwierig sein wird, sich weiterzuentwickeln. Glücklicherweise gibt es einige Kollegen, die wissen, wie man in die Falle tappt.
Ein Kollege hat mich gefragt, ob in Python nur das Paket importiert werden kann, wenn ein Modul und ein Paket denselben Namen haben? Was er meint, ist wahrscheinlich Folgendes: Im selben Verzeichnis des Projekts gibt es eine foo.py-Datei und ein foo/-Verzeichnis. Wenn import foo importiert wird, wird der Inhalt von foo/ anstelle des Inhalts von foo.py importiert .
Als mir diese Frage gestellt wurde, war das erste, was ich empfand, Überraschung. Es herrschte offensichtlich Unklarheit. Wenn ich es wäre, würde ich den Modulnamen und den Paketnamen definitiv nicht gleich gestalten, da es im Wesentlichen keine Möglichkeit gibt, beim Importieren zu unterscheiden, wer importiert werden soll. Sofern das System beispielsweise keine besonderen Bestimmungen vorsieht, ist festgelegt, dass in diesem Fall nur Pakete importiert werden können.
Ich denke unbewusst, dass hier ein Fehler gemeldet werden sollte, da der Python-Interpreter nicht weiß, wen er importieren soll. Ein Kollege sagte mir jedoch, dass der Code anderer Leute auf diese Weise geschrieben sei und in diesem Fall das Paket standardmäßig importiert werde. Das ist möglich und der Interpreter hat festgelegt, dass das Paket in diesem Fall immer importiert wird.
Um dies zu überprüfen, habe ich ein einfaches Projekt mit folgender Projektstruktur geschrieben:
. ├── main.py └── same ├── api │ └── init.py ├── auth │ └── init.py ├── auth.py └── init.py
Unter ihnen:
same/api/init/py Contents:
from .. import auth
same/auth/init.py Contents von:
auth_str = "This is str in package!"
same/auth.py Inhalt:
auth_str = "This is str in module!"Inhalt von
main.py:
from future import print_function from same.api import auth # Script starts from here if name == "main": print(auth.auth_str)
Es ist etwas kompliziert, haha, hauptsächlich weil die allgemeine Struktur meiner Kollegen so ist, hier zum besseren Verständnis Simulieren. Ich habe eine same.auth
auth_str
-Zeichenfolge im -Paket und eine same.auth
-Zeichenfolge mit demselben Namen im auth_str
-Modul mit demselben Namen definiert und dann versucht, sie in das zu importieren same.api-Paketauthentifizierung und versuchen Sie schließlich, same.api.auth.auth_str
in main.py auszugeben, um zu sehen, welche Zeichenfolge gedruckt wird. Versuchen Sie, main.py gleichzeitig mit Python2 und Python3 auszuführen. Die erhaltenen Ergebnisse sind:
This is str in package!
Dies bestätigt, dass unsere Vermutung und der Interpreter korrekt sind importiert nur den Inhalt des Pakets. Allerdings weiß ich nicht, ob es offizielle Informationen gibt, die besagen, dass dies der Fall ist, daher bin ich mir nicht sicher, ob es sich nur um einen Zufall handelt.
Also begann ich, nach Informationen zu suchen, um diese Schlussfolgerung zu überprüfen. Lassen Sie mich ehrlich sein. Für jemanden, dessen Englisch so schlecht ist, dass Sie es sich nicht einmal vorstellen können, kann ich nur versuchen, zuerst auf Baidu nach der Antwort zu suchen. Tatsache ist, dass die Verwendung von Baidu oft schade ist. Nach einer Weile blieb mir erfolglos nichts anderes übrig, als in den sauren Apfel zu beißen und die Suche auf Englisch zu versuchen. Also habe ich auf Stackoverflow die folgende Frage gefunden:
Wie geht Python mit Modulen und Paketen um, die denselben Namen haben?
Eine von ihnen antwortete, dass in der offiziellen Python-Dokumentation bei der Beschreibung des Modulsuchpfads erwähnt wird An dieser Stelle: docs.python.org/3/tutorial/modules.html#the-module-search-path.
Das Dokument hat die folgende Beschreibung:
Nach der Initialisierung werden Python-Programme erstellt kann sys.path ändern. Das Verzeichnis, das das ausgeführte Skript enthält, wird am Anfang des Suchpfads vor dem Standardbibliothekspfad platziert. Dies bedeutet, dass Skripte in diesem Verzeichnis anstelle von Modulen mit demselben Namen in der Bibliothek geladen werden Dies ist ein Fehler, sofern die Ersetzung nicht beabsichtigt ist. Weitere Informationen finden Sie im Abschnitt „Standardmodule“. Das heißt, das Verzeichnis wird zuerst unter dem Suchpfad der Bibliothek durchsucht Verzeichnis Wird anstelle des gleichnamigen Moduls geladen.
Endlich bin ich erleichtert, dass meine vorherige Schlussfolgerung bestätigt wurde. Wenn Sie in Python versuchen, ein Modul und ein Paket mit demselben Namen zu importieren, wird das Paket importiert. Wenn Sie das Modul in diesem Fall importieren möchten, müssen Sie möglicherweise einige „Hack“-Methoden verwenden. Im oben erwähnten Stackoverflow-Beitrag finden Sie einige Beispiele. Der beste Weg ist natürlich, ein solches Design zu vermeiden, damit Sie nicht so lange nach Informationen suchen und nicht so lange Artikel schreiben müssen, die diesem Artikel ähneln.
Zusammenfassung
[Verwandte Empfehlungen]
1 🎜>Besonders empfohlen: Download der Version „php Programmer Toolbox“ V0.1
2Kostenloses Python-Video-Tutorial3
Python-objektorientiertes Video-Tutorial
Das obige ist der detaillierte Inhalt vonLösung für die doppelten Namen von Python-Modulen und -Paketen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!