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

Data Lake y Data Warehouse: diferencias, usos y cómo se complementan en la era del dato

En la era del dato, las organizaciones se enfrentan al reto de gestionar volúmenes masivos…

3 días ago

Documentar tu API de Express con TypeScript usando OpenAPI (Swagger)

En la serie Creación de una API REST con Express y TypeScript construimos una API…

5 días ago

Curiosidad: El sesgo de supervivencia, o por qué prestar atención sólo a los que “llegaron” puede engañarte

Durante la Segunda Guerra Mundial, la Fuerza Aérea de Estados Unidos quería reforzar sus aviones…

1 semana ago

Cómo abrir una ventana de Chrome con tamaño y posición específicos desde la línea de comandos en Windows

En muchas situaciones —ya sea para grabar un tutorial, tomar capturas de pantalla profesionales, probar…

2 semanas ago

La Paradoja del Cumpleaños, o por qué no es tan raro compartir fecha de nacimiento

Imagínate en una sala con un grupo de personas, por ejemplo, en una oficina, un…

2 semanas ago

Programador de tareas de Windows: Guía definitiva para automatizar tu trabajo (BAT, PowerShell y Python)

En el trabajo diario con ordenadores, es común encontrarse con tareas repetitivas: realizar copias de…

3 semanas ago

This website uses cookies.