Python

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

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.

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.

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.

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?

Daniel Rodríguez

Share
Published by
Daniel Rodríguez

Recent Posts

De la Regresión Logística al Scorecard: La Transformación Matemática

En un entrada previa explicamos qué son el WOE y el IV y por qué…

20 horas ago

Analytics Lane lanza la versión 1.1 del laboratorio con nuevas suites de CLV y Scoring

Seguimos evolucionando el laboratorio de Analytics Lane y hoy lanzamos la versión 1.1, disponible en:…

2 días ago

Interés compuesto: la fuerza que multiplica tu dinero (y los errores que la anulan)

“El interés compuesto es la octava maravilla del mundo. El que lo entiende lo gana…

6 días ago

Cómo comparar datos con barras en Matplotlib: agrupadas, apiladas y porcentuales

Tienes los datos de ventas de tres productos en dos años distintos y quieres saber…

1 semana ago

Costes hundidos en ciencia de datos: cuándo mantener un modelo y cuándo migrar

Imagina la situación. Tu equipo lleva tres años con un modelo en producción. No es…

2 semanas ago

WOE e IV: La Base Matemática del Credit Scoring

Cuando un banco evalúa una solicitud de crédito necesita responder a una pregunta aparentemente simple:…

2 semanas ago

This website uses cookies.