13 KiB
Rich
Rich es un paquete de Python para texto enriquecido y un hermoso formato en la terminal.
La API Rich facilita la adición de color y estilo a la salida del terminal. Rich también puede representar tablas bonitas, barras de progreso, markdown, código fuente resaltado por sintaxis, trazas y más — listo para usar.
Para ver un vídeo de introducción a Rich, consulte calmcode.io de @fishnets88.
Vea lo que la gente dice sobre Rich.
Compatibilidad
Rich funciona con Linux, OSX y Windows. True color / emoji funciona con la nueva Terminal de Windows, la terminal clásica está limitada a 8 colores. Rich requiere Python 3.6.1 o posterior.
Rich funciona con Jupyter notebooks sin necesidad de configuración adicional.
Instalación
Instale con pip
o su administrador de paquetes PyPi favorito.
pip install rich
Función print de Rich
Para agregar sin esfuerzo resultados enriquecidos a su aplicación, puede importar el método rich print, que tiene la misma firma que el método incorporado de Python. Prueba esto:
from rich import print
print("Hello, [bold magenta]World[/bold magenta]!", ":vampire:", locals())
Rich REPL
Rich se puede instalar en Python REPL, por lo que cualquier estructura de datos se imprimirá y resaltará bastante.
>>> from rich import pretty
>>> pretty.install()
Usando la consola
Para tener más control sobre el contenido enriquecido del terminal, importe y cree un objeto Console.
from rich.console import Console
console = Console()
El objeto Console tiene un método print
que tiene una interfaz intencionalmente similar a la función incorporada print
. Aquí tienes un ejemplo de uso:
console.print("Hello", "World!")
Como era de esperar, esto imprimirá "Hello World!"
en la terminal. Tenga en cuenta que, a diferencia de la función print
incorporada, Rich ajustará su texto para ajustarlo al ancho de la terminal.
Hay algunas formas de agregar color y estilo a su salida. Puede establecer un estilo para toda la salida agregando un argumento de palabra clave style
. He aquí un ejemplo:
console.print("Hello", "World!", style="bold red")
La salida será similar a la siguiente:
Eso está bien para diseñar una línea de texto a la vez. Para un estilo más fino, Rich presenta un marcado especial que es similar en sintaxis a bbcode. He aquí un ejemplo:
console.print("Where there is a [bold cyan]Will[/bold cyan] there [u]is[/u] a [i]way[/i].")
Registro de consola
El objeto Console tiene un método log()
que tiene una interfaz similar a print()
, pero también muestra una columna para la hora actual y el archivo y la línea que realizó la llamada. De forma predeterminada, Rich resaltará la sintaxis de las estructuras de Python y de las cadenas de reproducción. Si registra una colección (es decir, un diccionario o una lista), Rich la imprimirá de forma bonita para que quepa en el espacio disponible. A continuación, se muestra un ejemplo de algunas de estas funciones.
from rich.console import Console
console = Console()
test_data = [
{"jsonrpc": "2.0", "method": "sum", "params": [None, 1, 2, 4, False, True], "id": "1",},
{"jsonrpc": "2.0", "method": "notify_hello", "params": [7]},
{"jsonrpc": "2.0", "method": "subtract", "params": [42, 23], "id": "2"},
]
def test_log():
enabled = False
context = {
"foo": "bar",
}
movies = ["Deadpool", "Rise of the Skywalker"]
console.log("Hello from", console, "!")
console.log(test_data, log_locals=True)
test_log()
Lo anterior produce el siguiente resultado:
Tenga en cuenta el argumento log_locals
, que genera una tabla que contiene las variables locales donde se llamó al método log.
El método de registro podría usarse para iniciar sesión en el terminal para aplicaciones de larga ejecución, como servidores, pero también es una ayuda de depuración muy buena.
Controlador de registro
También puede usar la Handler class incorporada para formatear y colorear la salida del módulo de registro de Python. Aquí hay un ejemplo de la salida:
Emoji
Para insertar un emoji en la salida de la consola, coloque el nombre entre dos puntos. He aquí un ejemplo:
>>> console.print(":smiley: :vampire: :pile_of_poo: :thumbs_up: :raccoon:")
😃 🧛 💩 👍 🦝
Utilice esta función con prudencia.
Tablas
Rich puede renderizar tablas flexibles con caracteres de cuadro Unicode. Existe una gran variedad de opciones de formato para bordes, estilos, alineación de celdas, etc.
La animación anterior se generó con table_movie.py en el directorio de ejemplos.
Aquí hay un ejemplo de tabla más simple:
from rich.console import Console
from rich.table import Table
console = Console()
table = Table(show_header=True, header_style="bold magenta")
table.add_column("Date", style="dim", width=12)
table.add_column("Title")
table.add_column("Production Budget", justify="right")
table.add_column("Box Office", justify="right")
table.add_row(
"Dev 20, 2019", "Star Wars: The Rise of Skywalker", "$275,000,000", "$375,126,118"
)
table.add_row(
"May 25, 2018",
"[red]Solo[/red]: A Star Wars Story",
"$275,000,000",
"$393,151,347",
)
table.add_row(
"Dec 15, 2017",
"Star Wars Ep. VIII: The Last Jedi",
"$262,000,000",
"[bold]$1,332,539,889[/bold]",
)
console.print(table)
Esto produce la siguiente salida:
Tenga en cuenta que el marcado de la consola se representa de la misma manera que print()
y log()
. De hecho, cualquier cosa que Rich pueda representar se puede incluir en los encabezados / filas (incluso en otras tablas).
La clase Table
es lo suficientemente inteligente como para cambiar el tamaño de las columnas para que se ajusten al ancho disponible de la terminal, ajustando el texto según sea necesario. Este es el mismo ejemplo, con la terminal más pequeña que la tabla anterior:
Barras de progreso
Rich puede representar varias barras de progreso sin parpadeos para realizar un seguimiento de las tareas de larga duración.
Para un uso básico, envuelva cualquier secuencia en la función track
e itere sobre el resultado. He aquí un ejemplo:
from rich.progress import track
for step in track(range(100)):
do_step(step)
No es mucho más difícil agregar varias barras de progreso. Aquí hay un ejemplo tomado de la documentación:
Las columnas pueden configurarse para mostrar los detalles que desee. Las columnas integradas incluyen porcentaje completado, tamaño de archivo, velocidad de archivo y tiempo restante. Aquí hay otro ejemplo que muestra una descarga en progreso:
Para probar esto usted mismo, consulte examples/downloader.py que puede descargar varias URL simultáneamente mientras muestra el progreso.
Columnas
Rich puede representar contenido en columnas ordenadas con un ancho igual u óptimo. Aquí hay un clon muy básico del comando (MacOS / Linux) ls
que muestra una lista de directorios en columnas:
import os
from rich import print
from rich.columns import Columns
directory = os.listdir(sys.argv[1])
print(Columns(directory))
La siguiente captura de pantalla es el resultado del ejemplo de columnas que muestra los datos extraídos de una API en columnas:
Markdown
Rich puede renderizar markdown y hace un trabajo razonable al traducir el formato al terminal.
Para renderizar markdown, importe la clase Markdown
y constrúyala con una cadena que contenga el código de markdown. Luego imprímalo en la consola. He aquí un ejemplo:
from rich.console import Console
from rich.markdown import Markdown
console = Console()
with open("README.md") as readme:
markdown = Markdown(readme.read())
console.print(markdown)
Esto producirá una salida similar a la siguiente:
Resaltado de sintaxis
Rich usa el paquete pygments para implementar resaltado de sintaxis. El uso es similar a renderizar markdown; construya un objeto Syntax
e imprímalo en la consola. He aquí un ejemplo:
from rich.console import Console
from rich.syntax import Syntax
my_code = '''
def iter_first_last(values: Iterable[T]) -> Iterable[Tuple[bool, bool, T]]:
"""Iterate and generate a tuple with a flag for first and last value."""
iter_values = iter(values)
try:
previous_value = next(iter_values)
except StopIteration:
return
first = True
for value in iter_values:
yield first, False, previous_value
first = False
previous_value = value
yield first, True, previous_value
'''
syntax = Syntax(my_code, "python", theme="monokai", line_numbers=True)
console = Console()
console.print(syntax)
Esto producirá el siguiente resultado:
Tracebacks
Rich puede representar tracebacks hermosos que son más fáciles de leer y muestran más código que los tracebacks estándar de Python. Puede configurar Rich como el controlador tracebacks predeterminado para que todas las excepciones sin capturar sean procesadas por Rich.
Así es como se ve en OSX (similar en Linux):
Proyecto usando Rich
Aquí hay algunos proyectos que usan Rich:
- BrancoLab/BrainRender un paquete de Python para la visualización de datos neuroanatómicos tridimensionales
- Ciphey/Ciphey Herramienta de descifrado automatizado
- emeryberger/scalene un perfilador de memoria y CPU de alta precisión y alto rendimiento para Python
- hedythedev/StarCli Explore los proyectos de tendencias de GitHub desde su línea de comando
- intel/cve-bin-tool Esta herramienta busca una serie de componentes vulnerables comunes (openssl, libpng, libxml2, expat y algunos otros) para informarle si su sistema incluye bibliotecas comunes con vulnerabilidades conocidas.
- nf-core/tools Paquete de Python con herramientas auxiliares para la comunidad nf-core.
- cansarigol/pdbr pdb + biblioteca Rich para una depuración mejorada
- plant99/felicette Imágenes de satélite para tontos.
- seleniumbase/SeleniumBase Automatice y pruebe 10 veces más rápido con Selenium y pytest. Baterias incluidas.
- smacke/ffsubsync Sincronice automáticamente los subtítulos con el video.
- tryolabs/norfair
- Libreria de Python para agregar tracking a cualquier detector.
- +¡Muchos más!