Warum gibt es in Python keine main()-Funktion?
In diesem Artikel werden wir verstehen, warum es in Python keine main()-Funktion gibt.
Es besteht kein Zweifel, dass Python keine sogenannte Hauptfunktion hat, aber bzgl Zitate wie „Primäre Funktionen von Python“ und „Vorschläge zum Schreiben Hauptfunktionen. "
Ihre Absicht besteht vielleicht darin, den ursprünglichen Hauptansatz zu reproduzieren, aber viele Lassen Sie sich in die Irre führen (oder missverstehen) und erstellen Sie dadurch äußerst komplexen Code.
Bevor wir beginnen, beantworten wir die folgenden zwei Fragen -
Was genau ist die „Hauptfunktion“?
Warum müssen einige Programmiersprachen die Hauptfunktion verwenden?
Einige Programmiersprachen wie C/C++, C#, Java, Go, Rust usw. verwenden Die Hauptfunktion hat als Ausführungseintrag des Programms eine bestimmte Bedeutung -
Dieser Hauptfunktionsname ist erforderlich, was bedeutet, dass es eine Hauptfunktion geben muss Funktion.
Da es nur eine Hauptfunktion geben kann, ist es jeder Eintrag des Programms einzigartig.
Das Syntaxformat stellt spezifische Anforderungen und folgt einem sehr konsistenten (festen) Vorlage.
Warum müssen wir die Haupteintragsfunktion festlegen? Obligatorisch?
Dies sind kompilierte Sprachen und erfordern, dass der Code in eine ausführbare Datei kompiliert wird Betriebssystem-/Bootloader-Binärdateien, um den Start des Programms zu finden Diese Funktion muss definiert werden.
Einfach ausgedrückt gibt es einen wichtigen Anfang, der in einer großen Menge an Inhalten definiert werden muss Ausführbarer Code.
Hauptmerkmale sind die grundlegenden organischen Merkmale dieser Sprachen.
Aber wenn wir zu Python zurückkehren, ändern sich die Dinge dramatisch.
Python ist eine interpretierte Sprache, auch bekannt als Skriptsprache. Das Der laufende Prozess läuft Zeile für Zeile von oben nach unten ab, was bedeutet, dass er Der Ausgangspunkt ist bekannt.
Jede .py-Datei ist eine ausführbare Datei, die als Einstiegspunkt eines Programms verwendet werden kann. bedeutet, dass der Einstiegspunkt des Programms flexibel ist und keiner Konvention folgen muss Folgt bereits.
Beim Ausführen eines Python-Projekts ohne Angabe einer Eintragsdatei (je mehr Eine typische Befehlszeile wie „python -m http.server 8000“), wahrscheinlich aufgrund Es gibt eine main.py-Datei, die als „Datei“ im Paket Folgendes ausführt arbeiten.
Zusammenfassend lässt sich sagen, dass sich die Skriptsprache Python von der kompilierten Sprache unterscheidet. es kann Wählen Sie flexible Ausführungstechniken auf der Ebene einzelner Module (z. B. .py-Dateien). oder auf Paketebene, bestehend aus vielen Modulen, im Gegensatz zu anderen Sprachen, die dies nicht können Dies kann ohne klar definierte Einträge erreicht werden.
Mit anderen Worten: Python verlangt von Programmierern nicht, einen einheitlichen Eintrag anzugeben (auch nicht). Es handelt sich um eine Funktion, eine Klasse oder ein anderes auf Syntaxebene.
Einige Benutzer sind möglicherweise verwirrt, weil sie häufig auf den folgenden Code stoßen oder ihn schreiben -
# defining the main function using the def keyword def main(): …… if __name__ == '__main__': main()
Ist das nicht die Hauptfunktion von Python? Ich glaube, viele Leute stimmen zu! -
Nein, ist es nicht.
Außer der Funktionsname ist „main“, er hat keine Verbindung mit dem orthodoxen main Die zuvor beschriebene Funktion ist nicht erforderlich und steuert nicht unbedingt die Reihenfolge Programmausführung. Ohne sie wird es keine Syntaxprobleme verursachen.
Manche Leute möchten eine „Haupt“-Funktion kennzeichnen, um ihren „Haupt“-Status hervorzuheben und Machen Sie dies zur ersten Funktion, die manuell ausgeführt wird.
Sie denken vielleicht, dass Funktionen mit solchen Namen leichter zu merken sind.Sie möchten möglicherweise if name =='main' schreiben, um zu beweisen, dass main() nur ausgeführt wird, wenn Das aktuelle Skript wird direkt ausgeführt und sollte beim Import nicht ausgeführt werden. andere Module.
Diesen Schreibstil empfehlen wir allerdings nicht.
Das häufigste Beispiel: nur ein paar Dutzend Codezeilen oder eine Skriptdatei Eine einfache Funktion implementiert (ein kleiner Crawler, der mit einer Schildkröte ein Bild zeichnet usw.), Aber sie sind alle auf die gleiche Weise geschrieben wie zuvor.
Aus folgenden Gründen wird nicht empfohlen, if
name__ == '__main' - zu schreiben
- Zuallererst, wenn Sie nur eine Datei haben, weil es keine Exportoption gibt.
- 2. Wenn mehrere Dateien vorhanden sind, schreiben Sie diesen Satz in die Eintragsdatei (main.py). Dringend entmutigt. Da es der Ausgangspunkt ist, sollte sein Inhalt nicht sein zur Verwendung in anderen Modulen exportiert.
- Schließlich ist es nicht möglich, dieses Urteil in eine Nichteintragsdatei mit vielen Dateien zu schreiben. Empfohlen, da Sie höchstens einige dieser Tests erstellen können Programm. Der Testcode sollte jedoch getrennt und separat gespeichert werden Verzeichnis oder Datei.
Zusammenfassung
- Befreien Sie sich vom Trägheitsdenken und erstellen Sie echten Code. Haupteintragsfunktion Ist für einige Sprachen spezifisch und sollte nicht in Python verwendet werden. Du solltest Verstehen Sie die Eigenschaften von Skriptsprachen und schreiben Sie in einer einfachen und verständlichen Sprache Attraktiver Stil.
Verwenden Sie main.py anstelle von main(). Denn die Programmausführungseinheit von Python ist Skriptdateien statt Funktionen oder Klassen, die Eintragsdatei sollte main.py heißen, Die interne Funktionalität wird durch Anforderungen bestimmt.
Wenn möglich, verwenden Sie main.py als Eingabedatei. Diese Datei ist sehr einfach zusammenzustellen und zu verwenden Verwenden Sie den Parameter „-m“ in der Befehlszeile.
Fazit
In diesem Artikel haben wir erfahren, warum Python im Gegensatz zu anderen Programmiersprachen Mängel aufweist Hauptfunktion. Wir haben auch etwas über die Bedingung __name__ == '__main__' erfahren.
Das obige ist der detaillierte Inhalt vonWarum gibt es in Python keine main()-Funktion?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undress AI Tool
Ausziehbilder kostenlos

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Um mit Quantum Machine Learning (QML) zu beginnen, ist das bevorzugte Tool Python und Bibliotheken wie Pennylane, Qiskit, TensorFlowquantum oder Pytorchquantum müssen installiert werden. Machen Sie sich dann mit dem Prozess vertraut, indem Sie Beispiele ausführen, z. B. Pennylane zum Aufbau eines Quanten neuronalen Netzwerks. Implementieren Sie das Modell dann gemäß den Schritten der Datensatzvorbereitung, der Datencodierung, der Erstellung parametrischer Quantenschaltungen, klassisches Optimierer -Training usw.; Im tatsächlichen Kampf sollten Sie es vermeiden, komplexe Modelle von Anfang an zu verfolgen, Hardwarebeschränkungen zu beachten, hybride Modellstrukturen einzusetzen und kontinuierlich auf die neuesten Dokumente und offiziellen Dokumente zu verweisen, um die Entwicklung zu verfolgen.

Dieser Artikel hat mehrere "Fertig" -Projekt-Websites von Python und "Blockbuster" -Portalen "Blockbuster" für Sie ausgewählt. Egal, ob Sie nach Entwicklungsinspiration suchen, den Quellcode auf Master-Ebene beobachten und lernen oder Ihre praktischen Fähigkeiten systematisch verbessern, diese Plattformen sind nicht zu übersehen und können Ihnen helfen, schnell zu einem Python-Meister zu werden.

Verwenden Sie Subprozess.run (), um die Befehle von Shell sicher auszuführen und die Ausgabe zu erfassen. Es wird empfohlen, Parameter in Listen zu übergeben, um Einspritzrisiken zu vermeiden. 2. Wenn die Shell -Eigenschaften erforderlich sind, können Sie Shell = True einstellen, aber achten Sie auf die Befehlsinjektion. 3. verwenden subprocess.popen, um die Echtzeit-Ausgangsverarbeitung zu realisieren. 4. Setzen Sie check = true, um Ausnahmen zu werfen, wenn der Befehl fehlschlägt. 5. Sie können direkt Ketten anrufen, um die Ausgabe in einem einfachen Szenario zu erhalten. Sie sollten Subprozess vorrangig machen. Die obigen Methoden überschreiben die Kernverwendung der Ausführung von Shell -Befehlen in Python.

Verwenden Sie die Jointplot von Seeborn, um die Beziehung und Verteilung zwischen zwei Variablen schnell zu visualisieren. 2. Das grundlegende Streudiagramm wird durch sns.jointplot (data = tips, x = "total_bill", y = "tip", sort = "scatter") implementiert, das Zentrum ist ein Streudiagramm und das Histogramm wird auf der oberen und unteren und rechten Seite angezeigt. 3. Fügen Sie Regressionslinien und Dichteinformationen zu einer Art "Reg" hinzu und kombinieren Sie Marginal_KWS, um den Edge -Plot -Stil festzulegen. 4. Wenn das Datenvolumen groß ist, wird empfohlen, "Hex" zu verwenden,

Um Python -Webcrawler zu beherrschen, müssen Sie drei Kernschritte erfassen: 1. Verwenden Sie Anfragen, um eine Anfrage zu initiieren, Webseiteninhalte durch GET -Methode zu erhalten, die Einstellung von Headern zu beachten, Ausnahmen zu bearbeiten und Robots.txt zu entsprechen. 2. Verwenden Sie BeautifulSoup oder XPath, um Daten zu extrahieren. Ersteres eignet sich zum einfachen Parsen, während letzteres flexibler und für komplexe Strukturen geeignet ist. 3.. Verwenden Sie Selen, um Browseroperationen für dynamische Ladeinhalte zu simulieren. Obwohl die Geschwindigkeit langsam ist, kann sie mit komplexen Seiten fertig werden. Sie können auch versuchen, eine Website -API -Schnittstelle zu finden, um die Effizienz zu verbessern.

Verwenden Sie httpx.asyncclient, um asynchrone HTTP -Anforderungen effizient zu initiieren. 1. Basic-Get-Anfragen verwalten Clients über Asyncwith und verwenden Sie AwaitClient.get, um nicht blockierende Anforderungen zu initiieren. 2. kombiniert asyncio.gather, sich mit asyncio zu kombinieren. Gather kann die Leistung erheblich verbessern, und die Gesamtzeit entspricht der langsamsten Anfrage. 3.. Unterstützen Sie benutzerdefinierte Header, Authentifizierung, Base_url und Zeitüberschreitungseinstellungen; 4. kann Postanfragen senden und JSON -Daten tragen; 5. Achten Sie darauf, dass das Mischen von synchronem asynchronem Code vermieden wird. Der Proxy-Support muss auf die Back-End-Kompatibilität achten, die für Crawlers oder API-Aggregation und andere Szenarien geeignet ist.

String -Listen können mit der join () -Methode wie '' .Join (Words) zusammengeführt werden, um "helloWorldfrompython" zu erhalten; 2. Die Zahlenlisten müssen vor dem Beitritt in Zeichenfolgen mit Karte (STR, Zahlen) oder [STR (x) ForxInnumbers] konvertiert werden. 3. Jede Typliste kann direkt in Zeichenfolgen mit Klammern und Zitaten umgewandelt werden, die zum Debuggen geeignet sind. 4. Benutzerdefinierte Formate können durch Generatorausdrücke in Kombination mit Join () implementiert werden, wie z.

Installieren Sie PYODBC: Verwenden Sie den Befehl pipinstallpyoDBC, um die Bibliothek zu installieren. 2. SQLServer verbinden: Verwenden Sie die Verbindungszeichenfolge, die Treiber, Server, Datenbank, UID/PWD oder Trusted_Connection über die Methode Pyodbc.Connect () und die SQL -Authentifizierung bzw. der Windows -Authentifizierung unterstützen; 3. Überprüfen Sie den installierten Treiber: Führen Sie Pyodbc.Drivers () aus und filtern Sie den Treibernamen mit 'SQLServer', um sicherzustellen, dass der richtige Treiberame wie 'ODBCDRIVER17 für SQLServer' verwendet wird. 4. Schlüsselparameter der Verbindungszeichenfolge
