Heim Backend-Entwicklung Python-Tutorial Optimieren von Python-Code mit cProfile und dem PyPy-Modul: Eine vollständige Anleitung

Optimieren von Python-Code mit cProfile und dem PyPy-Modul: Eine vollständige Anleitung

Sep 18, 2024 pm 07:37 PM

Optimizing Python Code Using cProfile and PyPy module: A Complete Guide

Einführung

Als Python-Entwickler konzentrieren wir uns oft darauf, unseren Code zum Laufen zu bringen, bevor wir uns um die Optimierung kümmern. Wenn es jedoch um umfangreiche Anwendungen oder leistungskritischen Code geht, ist die Optimierung von entscheidender Bedeutung. In diesem Beitrag stellen wir zwei leistungsstarke Tools vor, mit denen Sie Ihren Python-Code optimieren können: das cProfile-Modul und den PyPy-Interpreter.

Am Ende dieses Beitrags erfahren Sie:

  1. So identifizieren Sie Leistungsengpässe mithilfe des cProfile-Moduls.
  2. So optimieren Sie Ihren Code auf Geschwindigkeit.
  3. So verwenden Sie PyPy, um Ihre Python-Programme durch Just-in-Time-Kompilierung (JIT) weiter zu beschleunigen.

Warum Leistungsoptimierung wichtig ist

Python ist bekannt für seine Benutzerfreundlichkeit, Lesbarkeit und sein umfangreiches Ökosystem an Bibliotheken. Allerdings ist es aufgrund seiner interpretierten Natur auch langsamer als einige andere Sprachen wie C oder Java. Daher kann es bei leistungsempfindlichen Anwendungen wie maschinellen Lernmodellen, Echtzeitsystemen oder Hochfrequenzhandelssystemen von entscheidender Bedeutung sein, zu wissen, wie Sie Ihren Python-Code optimieren.

Die Optimierung folgt normalerweise diesen Schritten:

  1. Profilieren Sie Ihren Code, um zu verstehen, wo die Engpässe liegen.
  2. Optimieren Sie den Code in Bereichen, die ineffizient sind.
  3. Führen Sie den optimierten Code in einem schnelleren Interpreter wie PyPy aus, um maximale Leistung zu erzielen.

Jetzt beginnen wir mit der Profilierung Ihres Codes.

Schritt 1: Profilierung Ihres Codes mit cProfile

Was ist cProfile?

cProfile ist ein integriertes Python-Modul für die Leistungsprofilerstellung. Es verfolgt, wie viel Zeit jede Funktion in Ihrem Code zur Ausführung benötigt, was Ihnen dabei helfen kann, die Funktionen oder Codeabschnitte zu identifizieren, die zu Verlangsamungen führen.

Verwenden von cProfile über die Befehlszeile

Der einfachste Weg, ein Skript zu profilieren, besteht darin, cProfile über die Befehlszeile auszuführen. Nehmen wir zum Beispiel an, Sie haben ein Skript namens my_script.py:

python -m cProfile -s cumulative my_script.py
Nach dem Login kopieren

Erklärung:

  • -m cProfile: Führt das cProfile-Modul als Teil der Standardbibliothek von Python aus.
  • -s kumulativ: Sortiert die Profilerstellungsergebnisse nach der kumulierten Zeit, die in jeder Funktion verbracht wurde.
  • my_script.py: Ihr Python-Skript.

Dadurch wird eine detaillierte Aufschlüsselung darüber erstellt, wo Ihr Code seine Zeit verbringt.

Beispiel: Profilerstellung für ein Python-Skript

Sehen wir uns ein einfaches Python-Skript an, das Fibonacci-Zahlen rekursiv berechnet:

def fibonacci(n):
    if n <= 1:
        return n
    return fibonacci(n-1) + fibonacci(n-2)

if __name__ == "__main__":
    print(fibonacci(30))
Nach dem Login kopieren

Dieses Skript mit cProfile ausführen:

python -m cProfile -s cumulative fibonacci_script.py
Nach dem Login kopieren

Grundlegendes zur cProfile-Ausgabe

Sobald Sie cProfile ausführen, sehen Sie etwa Folgendes:

   ncalls  tottime  percall  cumtime  percall filename:lineno(function)
     8320    0.050    0.000    0.124    0.000 fibonacci_script.py:3(fibonacci)
Nach dem Login kopieren

Jede Spalte enthält wichtige Leistungsdaten:

  • ncalls: Anzahl der Aufrufe der Funktion.
  • tottime: Gesamtzeit, die in der Funktion verbracht wurde (ohne Unterfunktionen).
  • Cumtime: Kumulierte Zeit, die in der Funktion verbracht wurde (einschließlich Unterfunktionen).
  • pro Anruf: Zeit pro Anruf.

Wenn Ihre Fibonacci-Funktion zu viel Zeit in Anspruch nimmt, zeigt Ihnen diese Ausgabe, worauf Sie Ihre Optimierungsbemühungen konzentrieren sollten.

Profilierung bestimmter Teile Ihres Codes

Sie können cProfile auch programmgesteuert in Ihrem Code verwenden, wenn Sie nur bestimmte Abschnitte profilieren möchten.

import cProfile

def fibonacci(n):
    if n <= 1:
        return n
    return fibonacci(n-1) + fibonacci(n-2)

if __name__ == "__main__":
    cProfile.run('fibonacci(30)')
Nach dem Login kopieren

Schritt 2: Optimieren Sie Ihren Python-Code

Sobald Sie mit cProfile die Engpässe in Ihrem Code identifiziert haben, ist es Zeit für die Optimierung.

Gängige Python-Optimierungstechniken

  1. Eingebaute Funktionen verwenden: Integrierte Funktionen wie sum(), min() und max() sind in Python stark optimiert und normalerweise schneller als manuell implementierte Schleifen.

Beispiel:

   # Before: Custom sum loop
   total = 0
   for i in range(1000000):
       total += i

   # After: Using built-in sum
   total = sum(range(1000000))
Nach dem Login kopieren
  1. Unnötige Funktionsaufrufe vermeiden: Funktionsaufrufe verursachen Overhead, insbesondere innerhalb von Schleifen. Versuchen Sie, redundante Anrufe zu reduzieren.

Beispiel:

   # Before: Unnecessary repeated calculations
   for i in range(1000):
       print(len(my_list))  # len() is called 1000 times

   # After: Compute once and reuse
   list_len = len(my_list)
   for i in range(1000):
       print(list_len)
Nach dem Login kopieren
  1. Memoisierung: Bei rekursiven Funktionen können Sie die Memoisierung verwenden, um Ergebnisse teurer Berechnungen zu speichern und so wiederholte Arbeit zu vermeiden.

Beispiel:

   from functools import lru_cache

   @lru_cache(maxsize=None)
   def fibonacci(n):
       if n <= 1:
           return n
       return fibonacci(n-1) + fibonacci(n-2)
Nach dem Login kopieren

Dies beschleunigt die Fibonacci-Berechnung erheblich, indem die Ergebnisse jedes rekursiven Aufrufs gespeichert werden.

Schritt 3: Verwenden von PyPy für die Just-in-Time-Kompilierung

Was ist PyPy?

PyPy ist ein alternativer Python-Interpreter, der die Just-in-Time-Kompilierung (JIT) verwendet, um Ihren Python-Code zu beschleunigen. PyPy kompiliert häufig ausgeführte Codepfade in Maschinencode und ist damit für bestimmte Aufgaben viel schneller als der Standard-CPython-Interpreter.

Installing PyPy

You can install PyPy using a package manager like apt on Linux or brew on macOS:

# On Ubuntu
sudo apt-get install pypy3

# On macOS (using Homebrew)
brew install pypy3
Nach dem Login kopieren

Running Python Code with PyPy

Once PyPy is installed, you can run your script with it instead of CPython:

pypy3 my_script.py
Nach dem Login kopieren

Why Use PyPy?

  • PyPy is ideal for CPU-bound tasks where the program spends most of its time in computation (e.g., loops, recursive functions, number-crunching).
  • PyPy’s JIT compiler optimizes the code paths that are executed most frequently, which can result in significant speedups without any code changes.

Step 4: Combining cProfile and PyPy for Maximum Optimization

Now, let’s combine these tools to fully optimize your Python code.

Example Workflow

  1. Profile your code using cProfile to identify bottlenecks.
  2. Optimize your code using the techniques we discussed (built-ins, memoization, avoiding unnecessary function calls).
  3. Run your optimized code with PyPy to achieve additional performance improvements.

Let’s revisit our Fibonacci example and put everything together.

from functools import lru_cache

@lru_cache(maxsize=None)
def fibonacci(n):
    if n <= 1:
        return n
    return fibonacci(n-1) + fibonacci(n-2)

if __name__ == "__main__":
    import cProfile
    cProfile.run('print(fibonacci(30))')
Nach dem Login kopieren

After optimizing the code with memoization, run it using PyPy for further performance improvements:

pypy3 fibonacci_script.py
Nach dem Login kopieren

Conclusion

By leveraging cProfile and PyPy, you can greatly optimize your Python code. Use cProfile to identify and address performance bottlenecks in your code. Then, use PyPy to further boost your program’s execution speed through JIT compilation.

In summary:

  1. Profile your code with cProfile to understand performance bottlenecks.
  2. Apply Python optimization techniques, such as using built-ins and memoization.
  3. Run the optimized code on PyPy to achieve even better performance.

With this approach, you can make your Python programs run faster and more efficiently, especially for CPU-bound tasks.

Connect with me:
Github
Linkedin

Das obige ist der detaillierte Inhalt vonOptimieren von Python-Code mit cProfile und dem PyPy-Modul: Eine vollständige Anleitung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

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

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Wie löste ich das Problem der Berechtigungen beim Betrachten der Python -Version in Linux Terminal? Wie löste ich das Problem der Berechtigungen beim Betrachten der Python -Version in Linux Terminal? Apr 01, 2025 pm 05:09 PM

Lösung für Erlaubnisprobleme beim Betrachten der Python -Version in Linux Terminal Wenn Sie versuchen, die Python -Version in Linux Terminal anzuzeigen, geben Sie Python ein ...

Wie kann man vom Browser vermeiden, wenn man überall Fiddler für das Lesen des Menschen in der Mitte verwendet? Wie kann man vom Browser vermeiden, wenn man überall Fiddler für das Lesen des Menschen in der Mitte verwendet? Apr 02, 2025 am 07:15 AM

Wie kann man nicht erkannt werden, wenn Sie Fiddlereverywhere für Man-in-the-Middle-Lesungen verwenden, wenn Sie FiddLereverywhere verwenden ...

Wie kann ich die gesamte Spalte eines Datenrahmens effizient in einen anderen Datenrahmen mit verschiedenen Strukturen in Python kopieren? Wie kann ich die gesamte Spalte eines Datenrahmens effizient in einen anderen Datenrahmen mit verschiedenen Strukturen in Python kopieren? Apr 01, 2025 pm 11:15 PM

Bei der Verwendung von Pythons Pandas -Bibliothek ist das Kopieren von ganzen Spalten zwischen zwei Datenrahmen mit unterschiedlichen Strukturen ein häufiges Problem. Angenommen, wir haben zwei Daten ...

Wie hört Uvicorn kontinuierlich auf HTTP -Anfragen ohne Serving_forver () an? Wie hört Uvicorn kontinuierlich auf HTTP -Anfragen ohne Serving_forver () an? Apr 01, 2025 pm 10:51 PM

Wie hört Uvicorn kontinuierlich auf HTTP -Anfragen an? Uvicorn ist ein leichter Webserver, der auf ASGI basiert. Eine seiner Kernfunktionen ist es, auf HTTP -Anfragen zu hören und weiterzumachen ...

Wie löste ich Berechtigungsprobleme bei der Verwendung von Python -Verssionsbefehl im Linux Terminal? Wie löste ich Berechtigungsprobleme bei der Verwendung von Python -Verssionsbefehl im Linux Terminal? Apr 02, 2025 am 06:36 AM

Verwenden Sie Python im Linux -Terminal ...

Wie lehre ich innerhalb von 10 Stunden die Grundlagen für Computer-Anfänger-Programmierbasis in Projekt- und problemorientierten Methoden? Wie lehre ich innerhalb von 10 Stunden die Grundlagen für Computer-Anfänger-Programmierbasis in Projekt- und problemorientierten Methoden? Apr 02, 2025 am 07:18 AM

Wie lehre ich innerhalb von 10 Stunden die Grundlagen für Computer -Anfänger für Programmierungen? Wenn Sie nur 10 Stunden Zeit haben, um Computer -Anfänger zu unterrichten, was Sie mit Programmierkenntnissen unterrichten möchten, was würden Sie dann beibringen ...

Wie bekomme ich Nachrichtendaten, die den Anti-Crawler-Mechanismus von Investing.com umgehen? Wie bekomme ich Nachrichtendaten, die den Anti-Crawler-Mechanismus von Investing.com umgehen? Apr 02, 2025 am 07:03 AM

Verständnis der Anti-Crawling-Strategie von Investing.com Viele Menschen versuchen oft, Nachrichten von Investing.com (https://cn.investing.com/news/latest-news) zu kriechen ...

See all articles