• Saltar al contenido principal
  • Skip to secondary menu
  • Saltar a la barra lateral principal
  • Saltar al pie de página
  • Inicio
  • Secciones
    • Ciencia de datos
    • Criptografía
    • Herramientas
    • Machine Learning
    • Noticias
    • Opinión
    • Productividad
    • Programación
      • JavaScript
      • Julia
      • Matlab
      • Python
      • R
  • Programación
    • JavaScript
    • Julia
    • Matlab
    • Python
    • R
  • Laboratorio
    • Encuestas: Tamaño de Muestra
    • Lotería: Probabilidad de Ganar
    • Reparto de Escaños (D’Hondt)
    • Tres en Raya con IA
  • Noticias
  • Boletín
  • Contacto
  • Tienda
    • Libros
    • Equipamiento de oficina
    • Equipamiento en movilidad
    • Tiendas afiliadas
      • AliExpress
      • Amazon
      • Banggood
      • GeekBuying
      • Lenovo

Analytics Lane

Ciencia e ingeniería de datos aplicada

  • Ciencia de datos
  • Machine Learning
  • IA Generativa
  • Python
  • Pandas
  • NumPy
  • Excel
  • Matlab

Combinar gráficos con FacetGrid: Cómo analizar tendencias complejas en múltiples paneles con Seaborn

abril 21, 2025 Por Daniel Rodríguez Deja un comentario
Tiempo de lectura: 5 minutos

Al trabajar con conjuntos de datos complejos, a menudo puede ser necesario explorar las relaciones entre las variables de tipo categóricas y continuas. Por ejemplo:

  • ¿Cómo varían las ventas mensuales en función de la región y el tipo de producto?
  • ¿Cuáles son los grupos demográficos en los que se muestra una tendencia concreta en un estudio científico?

Generalmente, la representación de este tipo de relaciones en un único gráfico puede ser algo confuso y poco claro. Siendo en estos casos donde la clase FacetGrid de Seaborn se convierte en una herramienta imprescindible. FacetGrid permite mostrar los datos en paneles múltiples en función de una o más variables de tipo categórico, creando de este modo gráficos separados para cada subconjunto de datos.

En esta entrada, se mostrará cómo utilizar sns.FacetGrid() para explorar datos categóricos y continuos en paneles múltiples, facilitando el análisis de tendencias complejas.

Para qué sirve la clase sns.FacetGrid() de Seaborn

FacetGrid es una clase de Seaborn que permite:

  • Dividir un conjunto de datos en múltiples subconjuntos basados en una o más variables categóricas.
  • Crear un gráfico independiente para cada subconjunto.
  • Explorar visualmente patrones o tendencias específicas dentro de cada categoría.

Esto resulta útil cuando se desea realizar análisis en función de una variable dependiente de otras variables categóricas.

Publicidad


Uso básico de FacetGrid: Gráficos separados por una categoría

Supongamos que se tiene un conjunto de datos sobre el consumo de combustible en automóviles (que se puede importar de los ejemplos que existen en Seaborn) y se desea analizar cómo varía el consumo en función del tipo de combustible.

Curiosidad: El origen del análisis exploratorio de datos y el papel de John Tukey
En Analytics Lane
Curiosidad: El origen del análisis exploratorio de datos y el papel de John Tukey

import seaborn as sns
import matplotlib.pyplot as plt

# Cargar datos de ejemplo
mpg = sns.load_dataset("mpg")

# Crear un FacetGrid
g = sns.FacetGrid(mpg, col="origin", height=4, aspect=1.2)

# Graficar histogramas de millas por galón (mpg)
g.map(sns.histplot, "mpg", kde=True, color="blue")

# Títulos y etiquetas
g.set_titles("Origen: {col_name}")
g.set_axis_labels("Millas por galón", "Frecuencia")
g.tight_layout()

plt.show()

En este ejemplo, una vez importados los datos, se ha llamado al constructor de la clase FacetGrid() con el parámetro col="origin", lo que permite dividir los gráficos en columnas en función de la variable categórica origin. A continuación, se llama al método map() que crea un gráfico (en este caso, un histograma) para cada subconjunto de datos. Representándo cada uno de los paneles un subconjunto diferente de origin. El resultado después de ejecutar este código sería una figura como la que se muestra a continuación.

Grafica creada con FaceGrid en la que se ve tres histogramas con la distribución del consumo de los vehículos, uno para cada país de origen del conjunto de datos mpg
Tres graficas en la que se muestra la distribución del consumo de los vehículos en base al país de origen

Agregar múltiples dimensiones al análisis: Gráficos separados por filas y columnas

La clase FacetGrid permite añadir otra dimensión categórica usando el argumento row. Por ejemplo, se pueden dividir los datos en base al origin (columnas) y cylinders (filas, para el número de cilindros). Algo que se puede conseguir con el siguiente código:

# Crear un FacetGrid con filas y columnas
g = sns.FacetGrid(mpg, col="origin", row="cylinders", height=3, aspect=1.2)

# Graficar diagramas de dispersión (peso vs millas por galón)
g.map(sns.scatterplot, "weight", "mpg", color="purple", alpha=0.7)

# Títulos y etiquetas
g.set_titles("Origen: {col_name} | Cilindros: {row_name}")
g.set_axis_labels("Peso", "Millas por galón")
g.tight_layout()

plt.show()

En este ejemplo, cada panel está definido en función de una combinación de origin y cylinders. Lo que permite observar tendencias en subgrupos más específicos del conjunto de datos. El resultado de este código se puede ver en la siguiente figura.

Conjuntos de gráficos de dispersión en el que se muestra el consumo en millas por galón frente al peso para los vehículos en base al número de cilindros y origen de los vehículos.
Matriz con gráficas de dispersión que muestran el consumo en millas por galón frente al peso para los vehículos del conjunto de datos agrupados por origen y origen.

Publicidad


Personalización avanzada con FacetGrid: Agregar colores y estilos personalizados

Los gráficos se pueden personalizar con estilos, paletas de colores y leyendas. Esto es lo que se muestra en el siguiente ejemplo.

# Crear un FacetGrid con paleta de colores personalizada
palette = {"usa": "red", "europe": "green", "japan": "blue"}
g = sns.FacetGrid(mpg, col="origin", hue="origin", height=4, aspect=1.2, palette=palette)

# Graficar diagramas de dispersión
g.map(sns.scatterplot, "weight", "mpg", alpha=0.8)

# Agregar una leyenda
g.add_legend(title="Origen")
g.set_titles("Origen: {col_name}")
g.set_axis_labels("Peso", "Millas por galón")
g.tight_layout()

plt.show()

En este código, el parámetro hue colorea los puntos en función de la variable categórica origin. Además, también se agrega una leyenda para interpretar los colores. El resultado se muestra en la siguiente figura:

Figura creada con FaceGrid que muestra tres graficas de dispersión en la que se puede ver el consumo en millas por galón frente al peso para los vehículos de cada origen. Además, cada uno de los países se muestra con un color diferente.
Graficas de dispersión en la que se puede ver el consumo en millas por galón frente al peso para los vehículos de cada origen, asignado un color diferente a cada país.

Uso de funciones personalizadas en FacetGrid: Mapear funciones personalizadas

FacetGrid también permite el uso de funciones personalizadas para aplicar cálculos adicionales o personalizar el propio gráfico. Esto se puede ver en el siguiente ejemplo.

# Función personalizada para agregar líneas de tendencia
import numpy as np

def scatter_with_trend(x, y, **kwargs):
    sns.scatterplot(x=x, y=y, **kwargs)
    z = np.polyfit(x, y, 1)
    p = np.poly1d(z)
    plt.plot(x, p(x), color="orange", linestyle="--")

# Crear un FacetGrid
g = sns.FacetGrid(mpg, col="origin", height=4, aspect=1.2)

# Aplicar la función personalizada
g.map(scatter_with_trend, "weight", "mpg", alpha=0.7)

g.set_titles("Origen: {col_name}")
g.set_axis_labels("Peso", "Millas por galón")
g.tight_layout()

plt.show()

Aquí, la función personalizada scatter_with_trend añade líneas de tendencia a cada uno de los gráficos.

Figura creada con FaceGrid que muestra tres graficas de dispersión en la que se puede ver el consumo en millas por galón frente al peso para los vehículos de cada origen. En este caso, mediante una función personalizada, se ha agregado la regresión lineal para cada subconjunto de datos.
Graficas de dispersión en la que se puede ver el consumo en millas por galón frente al peso para los vehículos de cada origen en la que también ser muestra una regresión lineal para cada subconjunto.

Publicidad


Conclusiones

La clase FacetGrid de Seaborn es una opción interesante para la creación de gráficos complejos donde es necesario relacionar variables categorías con continuas. Algo que hace mediante la creación de gráficos con múltiples paneles. Facilitando con esto el análisis de tendencias y patrones en subconjuntos de datos, lo que permite la identificación de valores clave en los datos.

Ya sea para trabajar con datos demográficos, series temporales o cualquier otro tipo de información, FacetGrid permite crear visualizaciones claras y efectivas que destacan las relaciones más importantes.

¿Te ha parecido de utilidad el contenido?

¡Puntúalo entre una y cinco estrellas!

Puntuación promedio 0 / 5. Votos emitidos: 0

Ya que has encontrado útil este contenido...

¡Síguenos en redes sociales!

¡Siento que este contenido no te haya sido útil!

¡Déjame mejorar este contenido!

Dime, ¿cómo puedo mejorar este contenido?

Publicaciones relacionadas

  • Curiosidad: El origen del análisis exploratorio de datos y el papel de John Tukey
  • Cómo calcular el tamaño de la muestra para encuestas
  • Curiosidad: La Ley de Twyman y la trampa de los datos “interesantes”
  • Copias de seguridad automáticas en SQL Server con rotación de archivos
  • Curiosidad: La Paradoja de Simpson, o por qué no siempre debes fiarte de los promedios
  • Error npm ERR! code EACCES al instalar paquetes en Node.js: Cómo solucionarlo paso a paso
  • Curiosidad: La maldición de la dimensionalidad, o por qué añadir más datos puede empeorar tu modelo
  • ¿Está concentrado el MSCI World? Un análisis con Gini, Lorenz y leyes de potencia
  • Curiosidad: ¿Por qué usamos p < 0.05? Un umbral que cambió la historia de la ciencia

Publicado en: Python Etiquetado como: Seaborn

Interacciones con los lectores

Deja una respuesta Cancelar la respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *

I accept the Terms and Conditions and the Privacy Policy

Este sitio usa Akismet para reducir el spam. Aprende cómo se procesan los datos de tus comentarios.

Barra lateral principal

Suscríbete a nuestro boletín

Suscríbete al boletín semanal para estar al día de todas las publicaciones.

Política de Privacidad

Analytics Lane en redes sociales

  • Amazon
  • Bluesky
  • Facebook
  • GitHub
  • Instagram
  • Mastodon
  • Pinterest
  • RSS
  • Telegram
  • Tumblr
  • Twitter
  • YouTube

Publicidad

Entradas recientes

Curiosidad: ¿Por qué usamos p < 0.05? Un umbral que cambió la historia de la ciencia

octubre 2, 2025 Por Daniel Rodríguez

¿Está concentrado el MSCI World? Un análisis con Gini, Lorenz y leyes de potencia

septiembre 30, 2025 Por Daniel Rodríguez

Curiosidad: La maldición de la dimensionalidad, o por qué añadir más datos puede empeorar tu modelo

septiembre 25, 2025 Por Daniel Rodríguez

Publicidad

Es tendencia

  • Cerca La regresión logística publicado el julio 23, 2018 | en Ciencia de datos
  • Diferencias entre CPU, GPU, TPU y NPU publicado el abril 19, 2023 | en Herramientas
  • Gráficos de barras en Matplotlib publicado el julio 5, 2022 | en Python
  • Codificación JSON Archivos JSON con Python: lectura y escritura publicado el julio 16, 2018 | en Python
  • La pantalla del sistema operativo anfitrión no se adapta al de la pantalla en VirtualBox Configuración del tamaño de pantalla en VirtualBox publicado el noviembre 11, 2022 | en Herramientas

Publicidad

Lo mejor valorado

4.9 (24)

Seleccionar filas y columnas en Pandas con iloc y loc

4.6 (16)

Archivos JSON con Python: lectura y escritura

4.4 (14)

Ordenación de diccionarios en Python mediante clave o valor

4.7 (13)

Operaciones de filtrado de DataFrame con Pandas en base a los valores de las columnas

4.5 (10)

Diferencias entre var y let en JavaScript

Publicidad

Comentarios recientes

  • Daniel Rodríguez en Probabilidad básica: cómo entender el azar en nuestra vida diaria
  • Pepe en Probabilidad básica: cómo entender el azar en nuestra vida diaria
  • CARLOS ARETURO BELLO CACERES en Justicio: La herramienta gratuita de IA para consultas legales
  • Piera en Ecuaciones multilínea en Markdown
  • Daniel Rodríguez en Tutorial de Mypy para Principiantes

Publicidad


Footer

Analytics Lane

  • Acerca de Analytics Lane
  • Boletín de noticias
  • Contacto
  • Libros
  • Lo más popular
  • Noticias
  • Tienda
  • Tiendas afiliadas

Secciones

  • Ciencia de datos
  • Criptografía
  • Herramientas
  • Machine Learning
  • Opinión
  • Productividad
  • Programación
  • Reseñas

Sobre de Analytics Lane

En Analytics Lane tratamos de explicar los principales conceptos de la ciencia e ingeniería de datos con un enfoque práctico. Los principales temas tratados son ciencia de datos, ingeniería de datos, inteligencia artificial, machine learning, deep learning y criptografía. Además, también se habla de los principales lenguajes de programación y herramientas utilizadas por los científicos e ingenieros de datos.

Copyright © 2018-2025 Analytics Lane ·Términos y condiciones ·Política de Cookies ·Política de Privacidad ·Herramientas de privacidad ·Contacto