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 un entrada previa explicamos qué son el WOE y el IV y por qué…
Seguimos evolucionando el laboratorio de Analytics Lane y hoy lanzamos la versión 1.1, disponible en:…
“El interés compuesto es la octava maravilla del mundo. El que lo entiende lo gana…
Tienes los datos de ventas de tres productos en dos años distintos y quieres saber…
Imagina la situación. Tu equipo lleva tres años con un modelo en producción. No es…
Cuando un banco evalúa una solicitud de crédito necesita responder a una pregunta aparentemente simple:…
This website uses cookies.