Python

Barajar las filas de un DataFrame con Pandas

Los DataFrames de Pandas disponen del método sample() con el que se puede obtener una muestra aleatoria de los registros de un conjunto de datos. Método que se puede emplear para barajar las filas de un DataFrame. Veamos algunos de los usos que se le puede dar al método sample().

Conjunto de ejemplo

Antes de continuar es necesario disponer de un conjunto de datos de ejemplo. Para ello se puede crear uno aleatorio con la función randint() de NumPy y crear un DataFrame a partir de este.

import pandas as pd
import numpy as np

cols = 4
rows = 5

np.random.seed(0)

df = pd.DataFrame(np.random.randint(0,100, (rows, cols)))
df
    0   1   2   3
0  44  47  64  67
1  67   9  83  21
2  36  87  70  88
3  88  12  58  65
4  39  87  46  88

El método sample()

En Pandas todos los DataFrames cuentan con un método sample() que permite generar una muestra aleatoria de los elementos del objeto. Método cuyas principales propiedades son:

  • n: cantidad entera mediante la que se indica el número total de registros que se desea obtener, por defecto el valor es 1.
  • frac: fracción mediante la que se indica la fracción de las muestras que se desea obtener, cuando se usa este parámetro no se puede indicar al mismo tiempo un valor n.
  • replace: valor lógico con el que, si los valores extraídos pueden volver a salir posteriormente, esto es, si el muestreo se realiza mediante Bootstrap o Jackknife. El valor por defecto de esta propiedad es falso.
  • random_state: propiedad con la que se puede fijar la semilla del generador de números aleatorios usados.
  • axis: el eje en el que se desea realizar el muestreo. Por defecto se muestra por filas, pero también se puede indicar que la selección se realice por columnas.

Selección de unas filas aleatorias

El uso básico del método sample() es seleccionar una fila aleatoria del DataFrame, lo que se puede conseguir simplemente llamando al método

df.sample()
    0   1   2   3
2  36  87  70  88

Aunque puede ser más interesante seleccionar una cantidad de filas, por ejemplo, dos, y fijar la semilla, para que los resultados sean repetibles.

df.sample(2, random_state=0)
    0   1   2   3
2  36  87  70  88
0  44  47  64  67

También es posible indicar un porcentaje, por ejemplo, el 60% de los registros para obtener 3.

df.sample(frac=0.6, random_state=0)
    0   1   2   3
2  36  87  70  88
0  44  47  64  67
1  67   9  83  21

Recordando que en el caso de asignar un valor a la propiedad `frac` no se puede indicar un número de muestras, ya que en tal caso el método producirá un error.

Barajar las filas de un DataFrame

Así, si se desean barajar las filas del DataFrame lo único que hay que hacer es indicar que la fracción de datos sea el 100% del total. Como no hay repetición se obtendrán todas las filas originales, pero en distinto orden.

df.sample(frac=1, random_state=0)
    0   1   2   3
2  36  87  70  88
0  44  47  64  67
1  67   9  83  21
3  88  12  58  65
4  39  87  46  88

En este caso se puede recuperar la posición debido a que se conserva el índice, pero si se desea evitar este problema siempre se puede resetear el índice con el método reset_index().

df.sample(frac=1, random_state=0).reset_index(drop=True)
    0   1   2   3
0  36  87  70  88
1  44  47  64  67
2  67   9  83  21
3  88  12  58  65
4  39  87  46  88

Muestreo con repetición

Finalmente, también se puede realizar un muestreo con repetición, para lo que simplemente se deben asignar a la propiedad replace el valor de verdadero.

df.sample(frac=1, replace=True, random_state=0)
    0   1   2   3
4  39  87  46  88
0  44  47  64  67
3  88  12  58  65
3  88  12  58  65
3  88  12  58  65

En este caso se puede ver que la fila 3 aparece tres veces, al probar con otras semillas, o con valores de frac por encima de la unidad, las filas repetidas sean otras.

Conclusiones

En esta entrada se ha visto un método de los DataFrame Pandas con el que se puede realizar un muestreo de los registros. Algo que se puede emplear en simulaciones que requieren que barajar las filas de un DataFrame con Pandas.

¿Te ha parecido de utilidad el contenido?

Daniel Rodríguez

Share
Published by
Daniel Rodríguez
Tags: Pandas

Recent Posts

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é…

1 día 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:…

2 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…

6 días 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…

1 semana 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…

2 semanas ago

WOE e IV: La Base Matemática del Credit Scoring

Cuando un banco evalúa una solicitud de crédito necesita responder a una pregunta aparentemente simple:…

2 semanas ago

This website uses cookies.