Comment compter les valeurs distinctes par groupe chez les pandas ?

Linda Hamilton
Libérer: 2024-10-23 13:23:01
original
635 Les gens l'ont consulté

How to Count Distinct Values by Group in Pandas?

Équivalent Pandas : comptage distinct par groupe

Lors de l'utilisation de Pandas comme alternative à une base de données, il est souvent nécessaire d'effectuer des opérations complexes telles que le comptage distinct par groupe. Dans ce cas, nous voulons compter le nombre de clients distincts par an et par mois.

En SQL, cela peut être réalisé en utilisant la fonction d'agrégation count(distinct). Cependant, Pandas propose une syntaxe légèrement différente pour cette opération.

Pour compter les clients distincts par an et mois dans Pandas, on peut utiliser le code suivant :

<code class="python">table.groupby('YEARMONTH').CLIENTCODE.nunique()</code>
Copier après la connexion

La fonction groupby() divise le DataFrame en groupes en fonction de la colonne spécifiée (YEARMONTH dans ce cas). La fonction nunique() compte ensuite le nombre de valeurs uniques au sein de chaque groupe.

Voici un exemple pour illustrer :

<code class="python">import pandas as pd

# Create a DataFrame with sample data
data = {
    'YEARMONTH': ['201301', '201301', '201301', '201302', '201302', '201302', '201302'],
    'CLIENTCODE': [1, 1, 2, 1, 2, 2, 3]
}
table = pd.DataFrame(data)

# Count distinct clients per year month
result = table.groupby('YEARMONTH').CLIENTCODE.nunique()

print(result)</code>
Copier après la connexion

Sortie :

YEARMONTH
201301    2
201302    3
Copier après la connexion

Comme vous peut voir, le résultat correspond à la sortie attendue de la requête SQL.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!