• 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
  • R
  • Excel

Diferencia entre print y pprint en Python: Impresión de estructuras de datos complejas

mayo 27, 2024 Por Daniel Rodríguez Deja un comentario
Tiempo de lectura: 4 minutos

En Python, es habitual usar la función print para mostrar los resultados de una operación en la terminal. Siendo también muy utilizada para la depuración de código. Además de la función print, en Python existe el módulo pprint con el que es posible imprimir de forma más elegante y estructurada las estructuras de datos como las listas y diccionarios. En esta entrada se analizarán las diferencias que existen entre print y pprint viendo cuando la segunda ofrece ventajas sobre la primera.

El uso de la función print() en Python

La función print() es una función incorporada en Python, no es necesario importarla, con la que se puede imprimir datos en la salida estándar del sistema. Esto es, muestra los datos en la terminal o símbolo de sistema. Una función simple y directa que toma múltiples argumentos y los imprime para que el usuario los pueda ver. Un ejemplo básico de print() se puede ver en el siguiente código:

nombre = "Juan"
edad = 30
print("Hola,", nombre, "tienes", edad, "años.")

Cuando se ejecute este código se imprimirá:

Hola, Juan tienes 30 años.

Publicidad


El módulo pprint de Python

pprint es un módulo de biblioteca estándar de Python, en el que existe una función del mismo nombre, con el que se pueden imprimir datos en la salida estándar de una forma más elegante, legible y organizada que con la función print(). De hecho, el nombre del módulo es una abreviatura de “pretty print” (impresiones bonitas). Siendo una función de especial utilidad cuando se desean mostrar los valores de datos complejos como diccionarios o listas de gran tamaño.

Faker en Python: qué es, para qué sirve y cómo generar datos sintéticos realistas
En Analytics Lane
Faker en Python: qué es, para qué sirve y cómo generar datos sintéticos realistas

El objetivo principal de pprint es mostrar los datos de una forma más legible en la consola. Para lo que, en lugar de sacar todos los datos en una línea, formatea estos con sangrías y saltos de línea para resaltar la estructura. Mejorando la legibilidad de la salida en la consola.

Comparación entre el uso de print y pprint en Python

En esta sección se va a mostrar con ejemplo la diferencia que existe entre usar print y pprint en Python. En primer lugar, se puede ver la diferencia entre imprimir un diccionario con una función u otra.

from pprint import pprint

datos = [
    {'nombre': 'Juan', 'edad': 30},
    {'nombre': 'María', 'edad': 25},
    {'nombre': 'Pedro', 'edad': 35},
    {'nombre': 'Ana', 'edad': 28},
    {'nombre': 'Luis', 'edad': 40}
]

# Usando print()
print("Usando print():", datos)

# Usando pprint
print("Usando pprint():")
pprint(datos)
Usando print(): [{'nombre': 'Juan', 'edad': 30}, {'nombre': 'María', 'edad': 25}, {'nombre': 'Pedro', 'edad': 35}, {'nombre': 'Ana', 'edad': 28}, {'nombre': 'Luis', 'edad': 40}]
Usando pprint():
[{'edad': 30, 'nombre': 'Juan'},
{'edad': 25, 'nombre': 'María'},
{'edad': 35, 'nombre': 'Pedro'},
{'edad': 28, 'nombre': 'Ana'},
{'edad': 40, 'nombre': 'Luis'}]

En este ejemplo, en primer lugar se ha importado la función pprint() del módulo pprint. A diferencia de print() esta función no está incluida por defecto y es necesario importarla para poder usarla. Aunque está incluida la distribución estándar de Python.

Lo primero que se puede ver en el ejemplo es que print() saca por pantalla todos los elementos en una única línea, mientras que pprint() saca un elemento por línea. Haciendo más fácil la lectura de los datos para el usuario. Una diferencia que aún es más clara cuando el diccionario es más complejo como el que se muestra en el siguiente ejemplo.

datos = {
    'nombre': 'Juan',
    'edad': 30,
    'ciudad': 'Madrid',
    'profesion': 'Ingeniero',
    'experiencia': 8,
    'hobbies': ['fútbol', 'lectura', 'viajar'],
    'idiomas': ['español', 'inglés'],
    'educacion': {
        'universidad': 'UPM',
        'titulo': 'Ingeniería Informática'
    },
    'certificaciones': ['Certificado Python', 'Certificado AWS'],
    'proyectos': {
        'proyecto_1': 'Sistema de gestión de inventario',
        'proyecto_2': 'Plataforma de e-learning'
    }
}

# Usando print()
print("Usando print():", datos)

# Usando pprint
print("Usando pprint():")
pprint(datos)
Usando print(): {'nombre': 'Juan', 'edad': 30, 'ciudad': 'Madrid', 'profesion': 'Ingeniero', 'experiencia': 8, 'hobbies': ['fútbol', 'lectura', 'viajar'], 'idiomas': ['español', 'inglés'], 'educacion': {'universidad': 'UPM', 'titulo': 'Ingeniería Informática'}, 'certificaciones': ['Certificado Python', 'Certificado AWS'], 'proyectos': {'proyecto_1': 'Sistema de gestión de inventario', 'proyecto_2': 'Plataforma de e-learning'}}
Usando pprint():
{'certificaciones': ['Certificado Python', 'Certificado AWS'],
'ciudad': 'Madrid',
'edad': 30,
'educacion': {'titulo': 'Ingeniería Informática', 'universidad': 'UPM'},
'experiencia': 8,
'hobbies': ['fútbol', 'lectura', 'viajar'],
'idiomas': ['español', 'inglés'],
'nombre': 'Juan',
'profesion': 'Ingeniero',
'proyectos': {'proyecto_1': 'Sistema de gestión de inventario',
'proyecto_2': 'Plataforma de e-learning'}}

En ese ejemplo, analizar los datos con print() es todavía más complicado que con pprint().

Finalmente se puede ver lo que pasa cuando se tiene una matriz en una lista. En estos casos pprint() hace que sea más sencillo comprender los resultados ya que muestra las filas de la matriz por separado. Algo que se puede apreciar con el siguiente ejemplo.

matriz = [
    [1, 2, 3, 4, 5],
    [6, 7, 8, 9, 10],
    [11, 12, 13, 14, 15],
    [16, 17, 18, 19, 20],
    [21, 22, 23, 24, 25]
]

# Usando print()
print("Usando print():", matriz)

# Usando pprint
print("Usando pprint():")
pprint(matriz)
Usando print(): [[1, 2, 3, 4, 5], [6, 7, 8, 9, 10], [11, 12, 13, 14, 15], [16, 17, 18, 19, 20], [21, 22, 23, 24, 25]]
Usando pprint():
[[1, 2, 3, 4, 5],
[6, 7, 8, 9, 10],
[11, 12, 13, 14, 15],
[16, 17, 18, 19, 20],
[21, 22, 23, 24, 25]]

Un ejemplo que vuelve a demostrar como el uso de `pprint()` es más adecuado cundo se tiene datos complejos como una matriz o lista anidada.

Publicidad


Conclusiones

La función print() es una excelente opción para imprimir datos de manera rápida y simple en Python. Pero, cuando se trata de estructuras de datos complejas o de gran tamaño, pprint es una mejor opción ya que proporciona una salida más legible y estructurada. Así, cuando se trabaja con objetos complejos, tanto para depuración como para la salida de una aplicación, es aconsejable usar pprint() para ello. Usando print() para los casos más simples. Siendo este un criterio claro para seleccionar entre print y pprint en Python.

Imagen de Suzy en Pixabay

¿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

  • Faker en Python: qué es, para qué sirve y cómo generar datos sintéticos realistas
  • Probabilidades y tests: por qué un resultado positivo no significa lo que crees
  • JSON en bases de datos: cuándo es buena idea y cuándo no
  • Roles en ciencia de datos: Guía completa de perfiles técnicos
  • Exactitud, precisión, recall… qué mide realmente cada métrica (y qué no)
  • Hardening de SSH en Rocky Linux 9: cómo desactivar KEX débiles y reforzar la seguridad
  • Nueva herramienta en Analytics Lane: generador de contraseñas seguras y frases de contraseña
  • Hardening de NGINX en 2026: configuración segura básica paso a paso

Publicado en: Python

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

Hardening de NGINX en 2026: configuración segura básica paso a paso

marzo 12, 2026 Por Daniel Rodríguez

Nueva herramienta en Analytics Lane: generador de contraseñas seguras y frases de contraseña

marzo 10, 2026 Por Daniel Rodríguez

Hardening de SSH en Rocky Linux 9: cómo desactivar KEX débiles y reforzar la seguridad

marzo 5, 2026 Por Daniel Rodríguez

Publicidad

Es tendencia

  • Curiosidad: El origen del análisis exploratorio de datos y el papel de John Tukey publicado el septiembre 4, 2025 | en Ciencia de datos, Opinión
  • Cómo solucionar problemas de red en VirtualBox: Guía completa publicado el junio 11, 2025 | en Herramientas
  • Cómo calcular el tamaño de la muestra para encuestas publicado el septiembre 9, 2025 | en Ciencia de datos
  • Cómo instalar paquetes en Jupyter Notebook de forma eficiente: Guía completa con ejemplo publicado el febrero 3, 2025 | en Python
  • Gráfica con los datos y las anomalías detectadas con OneClass SVM One-Class SVM: Detección de anomalías con máquinas de vector soporte publicado el marzo 15, 2024 | en Ciencia de datos

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

  • M. Pilar en Cómo eliminar las noticias en Windows 11 y recuperar tu concentración
  • 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

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-2026 Analytics Lane ·Términos y condiciones ·Política de Cookies ·Política de Privacidad ·Herramientas de privacidad ·Contacto