Los DataFrame de Pandas son una excelente herramienta para procesar los conjuntos de datos. Con ellos es posible seleccionar los registros en base a los valores de las diferentes columnas o eliminar aquellos que no cumplan una condición. Algo que se puede hacer con valores numéricos, fechas y cadenas de texto. Pero ¿qué pasa cuando los registros de texto no son iguales? Por ejemplo, cuando existen cadenas con espacios en blanco. Para solucionar esto y poder comparar cadenas con espacios en Pandas se puede usar los métodos .srt que ofrece la librera.
Supongamos que se dispone de un DataFrame en el que se almacenan las referencias de una serie de productos como la que se muestra a continuación.
import pandas as pd
data = {
'Producto': ['Camiseta', 'Zapatos', 'Silla', 'Mesa', 'Cojín', 'Lámpara', 'Cubiertos'],
'Color': ['Blanco ', 'Azul', ' Negro', 'Blanco', 'blanco', ' blanco ', 'Verde'],
'Precio': [15.99, 49.99, 29.99, 79.99, 9.99, 39.99, 12.99],
'Stock': [20, 15, 10, 5, 30, 8, 25]
}
df = pd.DataFrame(data)
df Producto Color Precio Stock 0 Camiseta Blanco 15.99 20 1 Zapatos Azul 49.99 15 2 Silla Negro 29.99 10 3 Mesa Blanco 79.99 5 4 Cojín blanco 9.99 30 5 Lámpara blanco 39.99 8 6 Cubiertos Verde 12.99 25
Si se necesita seleccionar todos los productos que tiene como propiedad el color blanco se puede usar un simple filtrado del DataFrame como el que se muestra a continuación.
df[df.Color == 'Blanco']
Producto Color Precio Stock 3 Mesa Blanco 79.99 5
Pero, en este caso el resultado no es correcto, el primer registro del conjunto de datos tiene el color blanco, pero la cadena contiene un espacio al final. Para solucionar esto se puede usar el método .str.strip() disponibles en las Series de Pandas. Este método elimina los espacios no significativos, los que se muestran al principio y al final de la cadena, de todos los elementos de la serie, devolviendo un nuevo objeto. El cual se puede comparar con la cadena objetivo.
df[df.Color.str.strip() == 'Blanco']
Producto Color Precio Stock 0 Camiseta Blanco 15.99 20 3 Mesa Blanco 79.99 5
En el ejemplo anterior ya han obtenido los dos primeros registros con el color blanco, pero no el quinto y sexto que contiene la palabra en minúsculas. Para solucionar este problema se puede usar el método .str.lower() para hacer que todos las letras de la cadena sean minúsculas (o si se prefiere .str.upper() para hacer que todas las letras sean mayúsculas) y comparar con una cadena en minúsculas (o mayúsculas). El método se puede encadenar y aplicar después del anterior combinando ambas operaciones.
df[df.Color.str.strip().str.lower() == 'Blanco'.lower()]
Producto Color Precio Stock 0 Camiseta Blanco 15.99 20 3 Mesa Blanco 79.99 5 4 Cojín blanco 9.99 30 5 Lámpara blanco 39.99 8
En este caso también se ha usado el método .lower() que tienen las cadenas de texto en Python para convertir 'Blanco' en minúsculas. Obteniendo como resultado un DataFrame en el que se encuentra todos los productos de color blanco independientemente de que la cadena contenga o no espacios y esta esté escrita en mayúsculas o minúsculas.
En esta entrada se ha visto cómo usar el método str.lower() para comparar cadenas con espacios en Pandas y combinar con .str.lower(). Siendo un ejemplo de uso de los métodos .str de los que se dispone en Pandas para trabajar con texto. Conocer estas herramientas, y saber cómo combinarlas, es clave para poder sacar el máximo rendimiento de los DataFrame de Pandas cuando se trabaja con cadenas de texto.
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.