Python

Pandas: Contabilizar los registros que cumplen una condición en un DataFrame

La semana pasada hemos visto cómo se pueden contabilizar las veces que aparecen los valores nulos (NaN) en un DataFrame de Pandas. En esta ocasión vamos a generalizar el proceso para poder contabilizar los registros que cumplen una condición, sea esta sencilla o toda la compleja que necesitemos usar.

Conjunto de datos de ejemplo

Para trabajar se puede usar el mismo conjunto de datos utilizado la semana pasada, un conjunto de datos que se puede crear con el siguiente código.

import numpy as np
import pandas as pd

users = {'first_name': ['Montgomery', 'Dagmar', 'Reeba', 'Shalom', 'Broddy', 'Aurelia'],
         'last_name': ['Humes', 'Elstow', 'Wattisham', 'Alen', 'Keningham', 'Brechin'],
         'age': [27, np.NaN, 29, np.NaN, 21, 33],
         'gender': ['Male', 'Female', 'Female', np.NaN, 'Male', 'Female']}

df = pd.DataFrame(users)
df
   first_name  last_name   age  gender
0  Montgomery      Humes  27.0    Male
1      Dagmar     Elstow   NaN  Female
2       Reeba  Wattisham  29.0  Female
3      Shalom       Alen   NaN     NaN
4      Broddy  Keningham  21.0    Male
5     Aurelia    Brechin  33.0  Female

El conjunto de datos cuenta con cuatro columnas que se corresponden con el nombre, los apellidos, la edad y el género de uno clientes ficticios. Cada una de las seis filas se corresponde con uno de estos clientes.

Comprobar condiciones con apply()

El método apply() que está disponible en todos los DataFrames de Pandas permite ejecutar una función lambda con el código que deseemos. Función que se ejecutará a través de las filas o columnas, según se indique. El resultado de aplicar el método es un nuevo objeto que contendrá los valores devueltos por la función. En el caso de que este sea un valor lógico se podrá usar para contabilizar las filas o columnas que cumplen la condición indicada.

Por ejemplo, se puede buscar todos aquellos clientes que tengan una edad mayor de 25 años, para lo que solamente se tendría que ejecutar el siguiente código.

df.apply(lambda x: x['age'] > 25, axis=1)
0     True
1    False
2     True
3    False
4    False
5     True
dtype: bool

Nótese que se ha usado la propiedad axis igual a 1 para que la operación se realice a través de las filas, por lo que en la variable x de la función lambda se tendrá cada uno de los registros. Así para comprobar si la edad del resigno es superior a un valor solamente se tiene que comprobar en cada caso el resultado, devolviendo un valor verdadero o falso. Al ejecutarse la función tendremos como resultado una serie de valores lógicos. Así, tal como se vio la semana pasada, solamente hay que llamar al método sum() para obtener el número de registros que cumple la condición indicada.

df.apply(lambda x: x['age'] > 25, axis=1).sum()
3

Comprobar operaciones más complejas

Tal como se ha comentado anteriormente la función puede ser todos lo complejas que necesitemos, por lo que se puede comprobar cosas como los registros que son mayores de 25 años o nulos. Algo que se puede hacer mediante el siguiente código.

df.apply(lambda x: x['age'] > 25 or np.isnan(x['age']), axis=1).sum()
5

Conclusiones

En esta ocasión hemos visto cómo se puede crear una serie de valores lógicos con el método apply() y luego este resultado para contabilizar los registros que cumplen con una condición dada. Un método que nos ofrece múltiples posibilidades y amplia lo visto las semana pasada.

¿Te ha parecido de utilidad el contenido?

Daniel Rodríguez

Share
Published by
Daniel Rodríguez
Tags: Pandas

Recent Posts

Síndrome del objeto brillante en ciencia de datos: el error simétrico a los costes hundidos

Hace poco publiqué una entrada en la que trataba de un sesgo bien documentado: aferrarse…

4 días ago

De la Regresión Logística al Scorecard: La Transformación Matemática

En un entrada previa explicamos qué son el WOE y el IV y por qué…

6 días ago

Analytics Lane lanza la versión 1.1 del laboratorio con nuevas suites de CLV y Scoring

Seguimos evolucionando el laboratorio de Analytics Lane y hoy lanzamos la versión 1.1, disponible en:…

7 días ago

Interés compuesto: la fuerza que multiplica tu dinero (y los errores que la anulan)

“El interés compuesto es la octava maravilla del mundo. El que lo entiende lo gana…

2 semanas ago

Cómo comparar datos con barras en Matplotlib: agrupadas, apiladas y porcentuales

Tienes los datos de ventas de tres productos en dos años distintos y quieres saber…

2 semanas ago

Costes hundidos en ciencia de datos: cuándo mantener un modelo y cuándo migrar

Imagina la situación. Tu equipo lleva tres años con un modelo en producción. No es…

3 semanas ago

This website uses cookies.