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().
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
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.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.
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
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.
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.
En la era del dato, las organizaciones se enfrentan al reto de gestionar volúmenes masivos…
En la serie Creación de una API REST con Express y TypeScript construimos una API…
Durante la Segunda Guerra Mundial, la Fuerza Aérea de Estados Unidos quería reforzar sus aviones…
En muchas situaciones —ya sea para grabar un tutorial, tomar capturas de pantalla profesionales, probar…
Imagínate en una sala con un grupo de personas, por ejemplo, en una oficina, un…
En el trabajo diario con ordenadores, es común encontrarse con tareas repetitivas: realizar copias de…
This website uses cookies.