


Sieben Gewohnheiten zur Verbesserung der Leistung von Python-Programmen
1. Verwenden Sie lokale Variablen
Versuchen Sie, lokale Variablen anstelle globaler Variablen zu verwenden: um die Wartung zu erleichtern, die Leistung zu verbessern und Speicherplatz zu sparen.
Ersetzen Sie Variablen im Modul-Namespace durch lokale Variablen, zum Beispiel ls = os.linesep. Einerseits kann es die Programmleistung verbessern und die Suche nach lokalen Variablen beschleunigen; andererseits können kurze Bezeichner verwendet werden, um lange Modulvariablen zu ersetzen, um die Lesbarkeit zu verbessern.
2. Reduzieren Sie die Anzahl der Funktionsaufrufe
Bei der Beurteilung des Objekttyps ist die Verwendung von isinstance() die beste, die Verwendung der Objekttypidentität (id()) die zweitbeste und die Verwendung des Objektwerts (type()) ) ist das letzte.
#判断变量num是否为整数类型 type(num) == type(0) #调用三次函数 type(num) is type(0) #身份比较 isinstance(num,(int)) #调用一次函数
Fügen Sie den Inhalt wiederholter Vorgänge nicht als Parameter in Schleifenbedingungen ein, um wiederholte Vorgänge zu vermeiden.
#每次循环都需要重新执行len(a) while i < len(a): statement #len(a)仅执行一次 m = len(a) while i < m: statement
Wenn Sie eine Funktion oder ein Objekt Y in Modul X verwenden müssen, sollten Sie direkt from X import Y anstelle von import X.Y verwenden. Auf diese Weise kann bei Verwendung von Y eine Abfrage reduziert werden (der Interpreter muss nicht zuerst das X-Modul finden und dann im Wörterbuch des X-Moduls nach Y suchen).
3. Verwenden Sie Mapping anstelle der bedingten Suche.
Die Suchgeschwindigkeit von Mappings (z. B. Diktat usw.) ist viel schneller als bei bedingten Anweisungen (z. B. if usw.). In Python gibt es auch keine Select-Case-Anweisung.
#if查找 if a == 1: b = 10 elif a == 2: b = 20 ... #dict查找,性能更优 d = {1:10,2:20,...} b = d[a]
4. Sequenzelemente direkt iterieren
Bei Sequenzen (Str, Liste, Tupel usw.) ist das direkte Iterieren von Sequenzelementen schneller als das Iterieren des Index von Elementen.
a = [1,2,3] #迭代元素 for item in a: print(item) #迭代索引 for i in range(len(a)): print(a[i])
5. Verwenden Sie Generatorausdrücke, um das Listenverständnis zu ersetzen. Das Listenverständnis (Listenverständnis) generiert eine vollständige Liste, was sich negativ auf die Iteration großer Datenmengen auswirkt.
Der Generatorausdruck tut dies nicht, er erstellt eigentlich keine Liste, sondern gibt einen Generator zurück, der bei Bedarf einen Wert erzeugt (verzögerte Berechnung), was speicherschonender ist.
#计算文件f的非空字符个数 #生成器表达式 l = sum([len(word) for line in f for word in line.split()]) #列表解析 l = sum(len(word) for line in f for word in line.split())
6. Zuerst kompilieren und dann aufrufen
Wenn Sie die Funktionen eval() und exec() zum Ausführen von Code verwenden, ist es am besten, das Codeobjekt aufzurufen (vorher über die Funktion „compile()“ in Bytecode kompiliert). Anstatt str direkt aufzurufen, können wiederholte Kompilierungsvorgänge vermieden und die Programmleistung verbessert werden.
Der Mustervergleich für reguläre Ausdrücke ist ähnlich. Es ist auch am besten, das Muster für reguläre Ausdrücke in ein Regex-Objekt zu kompilieren (über die Funktion re.complie()), bevor Sie den Vergleich und den Abgleich durchführen.
7. Programmiergewohnheiten des Moduls
Die Python-Anweisung der höchsten Ebene (Code ohne Einrückung) im Modul wird ausgeführt, wenn das Modul importiert wird (unabhängig davon, ob die Ausführung wirklich erforderlich ist). Daher sollten Sie versuchen, alle Funktionscodes des Moduls in Funktionen zu packen, einschließlich der Funktionscodes, die sich auf das Hauptprogramm beziehen. Diese können auch in der Funktion main () platziert werden, und das Hauptprogramm selbst ruft die Funktion main () auf .
Sie können Testcode in die Funktion main() des Moduls schreiben. Überprüfen Sie im Hauptprogramm den Wert von „main“ (was anzeigt, dass das Modul direkt ausgeführt wird), rufen Sie die Funktion „main()“ auf und führen Sie einen Test durch, wenn es sich um den Namen des Moduls handelt Modul aufgerufen wird), wird kein Test durchgeführt.
Das obige ist der detaillierte Inhalt vonSieben Gewohnheiten zur Verbesserung der Leistung von Python-Programmen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

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

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

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

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)

Heiße Themen



PHP und Python haben ihre eigenen Vor- und Nachteile, und die Wahl hängt von den Projektbedürfnissen und persönlichen Vorlieben ab. 1.PHP eignet sich für eine schnelle Entwicklung und Wartung großer Webanwendungen. 2. Python dominiert das Gebiet der Datenwissenschaft und des maschinellen Lernens.

Python und JavaScript haben ihre eigenen Vor- und Nachteile in Bezug auf Gemeinschaft, Bibliotheken und Ressourcen. 1) Die Python-Community ist freundlich und für Anfänger geeignet, aber die Front-End-Entwicklungsressourcen sind nicht so reich wie JavaScript. 2) Python ist leistungsstark in Bibliotheken für Datenwissenschaft und maschinelles Lernen, während JavaScript in Bibliotheken und Front-End-Entwicklungsbibliotheken und Frameworks besser ist. 3) Beide haben reichhaltige Lernressourcen, aber Python eignet sich zum Beginn der offiziellen Dokumente, während JavaScript mit Mdnwebdocs besser ist. Die Wahl sollte auf Projektbedürfnissen und persönlichen Interessen beruhen.

Aktivieren Sie die Pytorch -GPU -Beschleunigung am CentOS -System erfordert die Installation von CUDA-, CUDNN- und GPU -Versionen von Pytorch. Die folgenden Schritte führen Sie durch den Prozess: Cuda und Cudnn Installation Bestimmen Sie die CUDA-Version Kompatibilität: Verwenden Sie den Befehl nvidia-smi, um die von Ihrer NVIDIA-Grafikkarte unterstützte CUDA-Version anzuzeigen. Beispielsweise kann Ihre MX450 -Grafikkarte CUDA11.1 oder höher unterstützen. Download und installieren Sie Cudatoolkit: Besuchen Sie die offizielle Website von Nvidiacudatoolkit und laden Sie die entsprechende Version gemäß der höchsten CUDA -Version herunter und installieren Sie sie, die von Ihrer Grafikkarte unterstützt wird. Installieren Sie die Cudnn -Bibliothek:

Docker verwendet Linux -Kernel -Funktionen, um eine effiziente und isolierte Anwendungsumgebung zu bieten. Sein Arbeitsprinzip lautet wie folgt: 1. Der Spiegel wird als schreibgeschützte Vorlage verwendet, die alles enthält, was Sie für die Ausführung der Anwendung benötigen. 2. Das Union File System (UnionFS) stapelt mehrere Dateisysteme, speichert nur die Unterschiede, speichert Platz und beschleunigt. 3. Der Daemon verwaltet die Spiegel und Container, und der Kunde verwendet sie für die Interaktion. 4. Namespaces und CGroups implementieren Container -Isolation und Ressourcenbeschränkungen; 5. Mehrere Netzwerkmodi unterstützen die Containerverbindung. Nur wenn Sie diese Kernkonzepte verstehen, können Sie Docker besser nutzen.

Minio-Objektspeicherung: Hochleistungs-Bereitstellung im Rahmen von CentOS System Minio ist ein hochleistungsfähiges, verteiltes Objektspeichersystem, das auf der GO-Sprache entwickelt wurde und mit Amazons3 kompatibel ist. Es unterstützt eine Vielzahl von Kundensprachen, darunter Java, Python, JavaScript und Go. In diesem Artikel wird kurz die Installation und Kompatibilität von Minio zu CentOS -Systemen vorgestellt. CentOS -Versionskompatibilitätsminio wurde in mehreren CentOS -Versionen verifiziert, einschließlich, aber nicht beschränkt auf: CentOS7.9: Bietet einen vollständigen Installationshandbuch für die Clusterkonfiguration, die Umgebungsvorbereitung, die Einstellungen von Konfigurationsdateien, eine Festplattenpartitionierung und Mini

Pytorch Distributed Training on CentOS -System erfordert die folgenden Schritte: Pytorch -Installation: Die Prämisse ist, dass Python und PIP im CentOS -System installiert sind. Nehmen Sie abhängig von Ihrer CUDA -Version den entsprechenden Installationsbefehl von der offiziellen Pytorch -Website ab. Für CPU-Schulungen können Sie den folgenden Befehl verwenden: PipinstallTorChTorChVisionTorChaudio Wenn Sie GPU-Unterstützung benötigen, stellen Sie sicher, dass die entsprechende Version von CUDA und CUDNN installiert ist und die entsprechende Pytorch-Version für die Installation verwenden. Konfiguration der verteilten Umgebung: Verteiltes Training erfordert in der Regel mehrere Maschinen oder mehrere Maschinen-Mehrfach-GPUs. Ort

Bei der Installation von PyTorch am CentOS -System müssen Sie die entsprechende Version sorgfältig auswählen und die folgenden Schlüsselfaktoren berücksichtigen: 1. Kompatibilität der Systemumgebung: Betriebssystem: Es wird empfohlen, CentOS7 oder höher zu verwenden. CUDA und CUDNN: Pytorch -Version und CUDA -Version sind eng miteinander verbunden. Beispielsweise erfordert Pytorch1.9.0 CUDA11.1, während Pytorch2.0.1 CUDA11.3 erfordert. Die Cudnn -Version muss auch mit der CUDA -Version übereinstimmen. Bestimmen Sie vor der Auswahl der Pytorch -Version unbedingt, dass kompatible CUDA- und CUDNN -Versionen installiert wurden. Python -Version: Pytorch Official Branch

Im VS -Code können Sie das Programm im Terminal in den folgenden Schritten ausführen: Erstellen Sie den Code und öffnen Sie das integrierte Terminal, um sicherzustellen, dass das Codeverzeichnis mit dem Terminal Working -Verzeichnis übereinstimmt. Wählen Sie den Befehl aus, den Befehl ausführen, gemäß der Programmiersprache (z. B. Pythons Python your_file_name.py), um zu überprüfen, ob er erfolgreich ausgeführt wird, und Fehler auflösen. Verwenden Sie den Debugger, um die Debugging -Effizienz zu verbessern.
