Introduction au data engineering
Vincent Vankrunkelsven
Data Engineer @ DataCamp
Base des outils modernes de traitement des données
Idée


Gérer un atelier de tailleur
Objectif : 100 chemises
Plusieurs tailleurs ensemble > meilleur tailleur seul
Puce de mémoire RAM:

Surcharge due aux communications
Ralentissement en parallèle:


multiprocessing.Pool
from multiprocessing import Pooldef take_mean_age(year_and_group): year, group = year_and_group return pd.DataFrame({"Age": group["Age"].mean()}, index=[year])with Pool(4) as p: results = p.map(take_mean_age, athlete_events.groupby("Year"))result_df = pd.concat(results)
dask
import dask.dataframe as dd# Fractionner le DataFrame en 4 athlete_events_dask = dd.from_pandas(athlete_events, npartitions = 4)# Lancer des calculs parallèles sur chaque partition result_df = athlete_events_dask.groupby('Year').Age.mean().compute()
Introduction au data engineering