Données catégorielles dans pandas

Utilisation de données catégorielles dans Python

Kasey Jones

Research Data Scientist

dtypes : object

adult = pd.read_csv("data/adult.csv")
adult.dtypes
Age                 int64
Workclass          object
fnlgwt              int64
Education          object
Education Num       int64
Marital Status     object
Occupation         object
Relationship       object
...
Utilisation de données catégorielles dans Python

dtypes : catégoriel

dtype par défaut :

adult["Marital Status"].dtype
dtype('O')

Définir comme catégoriel :

adult["Marital Status"] = adult["Marital Status"].astype("category")
adult["Marital Status"].dtype
CategoricalDtype(categories=[' Divorced', ' Married-AF-spouse',
' Married-civ-spouse', ' Married-spouse-absent', ' Never-married',
' Separated', ' Widowed'], ordered=False)
Utilisation de données catégorielles dans Python

Créer une Series catégorielle

my_data = ["A", "A", "C", "B", "C", "A"]
my_series1 = pd.Series(my_data, dtype="category")
print(my_series1)
0    A
1    A
2    C
...
dtype: category
Categories (3, object): [A, B, C]
Utilisation de données catégorielles dans Python

Créer une Series catégorielle

my_data = ["A", "A", "C", "B", "C", "A"]
my_series2 = pd.Categorical(my_data, categories=["C", "B", "A"], ordered=True)
my_series2
[A, A, C, B, C, A]
Categories (3, object): [C < B < A]
Utilisation de données catégorielles dans Python

Pourquoi utiliser les catégories : mémoire

Économie de mémoire :

adult = pd.read_csv("data/adult.csv")
adult["Marital Status"].nbytes
260488
adult["Marital Status"] = adult["Marital Status"].astype("category")
adult["Marital Status"].nbytes
32617
Utilisation de données catégorielles dans Python

Spécifier les dtypes à la lecture

  1. Créer un dictionnaire :

    adult_dtypes = {"Marital Status": "category"}
    
  2. Définir le paramètre dtype :

    adult = pd.read_csv("data/adult.csv", dtype=adult_dtypes)
    
  3. Vérifier le dtype :

    adult["Marital Status"].dtype
    
CategoricalDtype(categories=[' Divorced', ' Married-AF-spouse',
                             ..., ' Widowed'], ordered=False)
Utilisation de données catégorielles dans Python

Exercice sur les catégories pandas

Utilisation de données catégorielles dans Python

Preparing Video For Download...