Code-Profiling: Laufzeit

Effizienten Python-Code schreiben

Logan Thomas

Scientific Software Technical Trainer, Enthought

Code-Profiling

  • Detaillierte Statistiken zur Häufigkeit und Dauer von Funktionsaufrufen
  • Zeile-für-Zeile-Analysen
  • Verwendetes Paket: line_profiler
pip install line_profiler
Effizienten Python-Code schreiben

Code-Profiling: Laufzeit

heroes = ['Batman', 'Superman', 'Wonder Woman']

hts = np.array([188.0, 191.0, 183.0])

wts = np.array([ 95.0, 101.0,  74.0])
Effizienten Python-Code schreiben
def convert_units(heroes, heights, weights):

    new_hts = [ht * 0.39370  for ht in heights]
    new_wts = [wt * 2.20462  for wt in weights]

    hero_data = {}

    for i,hero in enumerate(heroes):
        hero_data[hero] = (new_hts[i], new_wts[i])

    return hero_data
convert_units(heroes, hts, wts)
{'Batman': (74.0156, 209.4389),
 'Superman': (75.1967, 222.6666),
 'Wonder Woman': (72.0471, 163.1419)}
Effizienten Python-Code schreiben

Code-Profiling: Laufzeit

%timeit convert_units(heroes, hts, wts)
3 µs ± 32 ns per loop (mean ± std. dev. of 7 runs, 100000 loops each)
Effizienten Python-Code schreiben
%timeit new_hts = [ht * 0.39370  for ht in hts]
1.09 µs ± 11 ns per loop (mean ± std. dev. of 7 runs, 1000000 loops each)
%timeit new_wts = [wt * 2.20462  for wt in wts]
1.08 µs ± 6.42 ns per loop (mean ± std. dev. of 7 runs, 1000000 loops each)
%%timeit
hero_data = {}
for i,hero in enumerate(heroes):
    hero_data[hero] = (new_hts[i], new_wts[i])
634 ns ± 9.29 ns per loop (mean ± std. dev. of 7 runs, 1000000 loops each)
Effizienten Python-Code schreiben

Code-Profiling: line_profiler

Mit dem Paket line_profiler

%load_ext line_profiler

Magischer Befehl für Zeiten pro Zeile

%lprun -f
Effizienten Python-Code schreiben

Code-Profiling: line_profiler

Mit dem Paket line_profiler

%load_ext line_profiler

Magischer Befehl für Zeiten pro Zeile

%lprun -f convert_units
Effizienten Python-Code schreiben

Code-Profiling: line_profiler

Mit dem Paket line_profiler

%load_ext line_profiler

Magischer Befehl für Zeiten pro Zeile

%lprun -f convert_units convert_units(heroes, hts, wts)
Effizienten Python-Code schreiben

%lprun-Ausgabe

%lprun -f convert_units convert_units(heroes, hts, wts)

alt=”Magic command lprun tabular output summarizing runtime profiling statistics”

Effizienten Python-Code schreiben

%lprun-Ausgabe

%lprun -f convert_units convert_units(heroes, hts, wts)

alt=”Magic command lprun tabular output summarizing runtime profiling statistics with Line # and Hits columns highlighted”

Effizienten Python-Code schreiben

%lprun-Ausgabe

%lprun -f convert_units convert_units(heroes, hts, wts)

alt=”Magic command lprun tabular output summarizing runtime profiling statistics with Time column highlighted”

Effizienten Python-Code schreiben

%lprun-Ausgabe

%lprun -f convert_units convert_units(heroes, hts, wts)

alt=”Magic command lprun tabular output summarizing runtime profiling statistics with first line Time unit highlighted”

Effizienten Python-Code schreiben

%lprun-Ausgabe

%lprun -f convert_units convert_units(heroes, hts, wts)

alt=”Magic command lprun tabular output summarizing runtime profiling statistics with line three highlighted”

Effizienten Python-Code schreiben

%lprun-Ausgabe

%lprun -f convert_units convert_units(heroes, hts, wts)

alt=”Magic command lprun tabular output summarizing runtime profiling statistics with Per Hit column highlighted”

Effizienten Python-Code schreiben

%lprun-Ausgabe

%lprun -f convert_units convert_units(heroes, hts, wts)

Magic command lprun tabular output summarizing runtime profiling statistics with line nine highlighted

Effizienten Python-Code schreiben

%lprun-Ausgabe

%lprun -f convert_units convert_units(heroes, hts, wts)

alt=”Magic command lprun tabular output summarizing runtime profiling statistics with % Time column highlighted”

Effizienten Python-Code schreiben

%lprun-Ausgabe

%lprun -f convert_units convert_units(heroes, hts, wts)

alt=”Magic command lprun tabular output summarizing runtime profiling statistics with Line Contents column highlighted”

Effizienten Python-Code schreiben
%timeit convert_units convert_units(heroes, hts, wts)
3 µs ± 32 ns per loop (mean ± std. dev. of 7 runs, 100000 loops each)
%lprun -f convert_units convert_units(heroes, hts, wts)

alt="Magic command lprun tabular output summarizing runtime profiling statistics with second line Total time highlighted"

Effizienten Python-Code schreiben

Lass uns deine neuen Pofiling-Fähigkeiten trainieren!

Effizienten Python-Code schreiben

Preparing Video For Download...