Élimination des boucles

Écrire du code Python efficace

Logan Thomas

Scientific Software Technical Trainer, Enthought

Les boucles dans Python

  • Motifs de boucle :
    • Boucle for : itérer sur la séquence élément par élément
    • Boucle while : répéter la boucle tant que la condition est remplie
    • Boucles « imbriquées » : utiliser une boucle à l'intérieur d'une autre boucle
    • Coûteux !
Écrire du code Python efficace

Avantages de l'élimination des boucles

  • Moins de lignes de code
  • Meilleure lisibilité du code
    • « Les fichiers plats sont préférables aux fichiers imbriqués »
  • Gains d'efficacité
Écrire du code Python efficace

Élimination des boucles avec les fonctions intégrées

# List of HP, Attack, Defense, Speed
poke_stats = [
    [90,  92, 75, 60],
    [25,  20, 15, 90],
    [65, 130, 60, 75],
    ...
]

alt=”The Pokémon named Abomasnow, Abra, and Absol and their corresponding Health Points, Attack, Defense, and Speed metadata highlighted”

Écrire du code Python efficace
# List of HP, Attack, Defense, Speed
poke_stats = [
    [90,  92, 75, 60],
    [25,  20, 15, 90],
    [65, 130, 60, 75],
    ...
]

# For loop approach totals = [] for row in poke_stats: totals.append(sum(row))
# List comprehension totals_comp = [sum(row) for row in poke_stats]
# Built-in map() function totals_map = [*map(sum, poke_stats)]
Écrire du code Python efficace
%%timeit
totals = []
for row in poke_stats:
    totals.append(sum(row))
140 µs ± 1.94 µs per loop (mean ± std. dev. of 7 runs, 10000 loops each)
%timeit totals_comp = [sum(row) for row in poke_stats]
114 µs ± 3.55 µs per loop (mean ± std. dev. of 7 runs, 10000 loops each)
%timeit totals_map = [*map(sum, poke_stats)]
95 µs ± 2.94 µs per loop (mean ± std. dev. of 7 runs, 10000 loops each)
Écrire du code Python efficace

Élimination des boucles avec les modules intégrés

poke_types = ['Bug', 'Fire', 'Ghost', 'Grass', 'Water']
# Nested for loop approach
combos = []
for x in poke_types:
    for y in poke_types:
        if x == y:
            continue
        if ((x,y) not in combos) & ((y,x) not in combos):
            combos.append((x,y))
# Built-in module approach
from itertools import combinations
combos2 = [*combinations(poke_types, 2)]
Écrire du code Python efficace

Éliminer les boucles avec NumPy

# Array of HP, Attack, Defense, Speed
import numpy as np

poke_stats = np.array([
    [90,  92, 75, 60],
    [25,  20, 15, 90],
    [65, 130, 60, 75],
    ...
])
Écrire du code Python efficace

Éliminer les boucles avec NumPy

avgs = []
for row in poke_stats:
    avg = np.mean(row)
    avgs.append(avg)

print(avgs)
[79.25, 37.5, 82.5, ...]
avgs_np = poke_stats.mean(axis=1)

print(avgs_np)
[ 79.25  37.5   82.5  ...]
Écrire du code Python efficace

Éliminer les boucles avec NumPy

%timeit avgs = poke_stats.mean(axis=1)
23.1 µs ± 235 ns per loop (mean ± std. dev. of 7 runs, 10000 loops each)
%%timeit
avgs = []
for row in poke_stats:
    avg = np.mean(row)
    avgs.append(avg)
5.54 ms ± 224 µs per loop (mean ± std. dev. of 7 runs, 100 loops each)
Écrire du code Python efficace

Passons à la pratique !

Écrire du code Python efficace

Preparing Video For Download...