From 8745ee5a1139fc101a382e4b178c89b432c487e3 Mon Sep 17 00:00:00 2001 From: Will McGugan Date: Fri, 1 Apr 2022 14:49:02 +0100 Subject: [PATCH] progress docs --- docs/source/progress.rst | 4 ++-- examples/file_progress.py | 16 ++++++++++++++++ examples/save_table_svg.py | 26 ++++++++++++++++++++++++++ rich/console.py | 2 +- 4 files changed, 45 insertions(+), 3 deletions(-) create mode 100644 examples/file_progress.py create mode 100644 examples/save_table_svg.py diff --git a/docs/source/progress.rst b/docs/source/progress.rst index 9a739f864..59813a473 100644 --- a/docs/source/progress.rst +++ b/docs/source/progress.rst @@ -212,7 +212,7 @@ If the :class:`~rich.progress.Progress` class doesn't offer exactly what you nee Reading from a file ~~~~~~~~~~~~~~~~~~~ -Rich provides an easy way to generate a progress bar for reading a file. If you call :func:`~rich.progress.open` it will return a context manager which displays a progress bar while you read. +Rich provides an easy way to generate a progress bar for reading a file. If you call :func:`~rich.progress.open` it will return a context manager which displays a progress bar while you read. This is particularly useful when you can't easily modify the code that does the reading. The following example shows how we might show progress for reading a JSON file:: @@ -223,7 +223,7 @@ The following example shows how we might show progress for reading a JSON file:: data = json.load(file) print(data) -If you already have a file object, you can call :func:`~rich.progress.wrap_file` which returns a context manager that wraps your file so that it generates a progress bar. If you use this function you will need to set the number of bytes or characters you expect to read. +If you already have a file object, you can call :func:`~rich.progress.wrap_file` which returns a context manager that wraps your file so that it displays a progress bar. If you use this function you will need to set the number of bytes or characters you expect to read. Here's an example that reads a url from the internet:: diff --git a/examples/file_progress.py b/examples/file_progress.py new file mode 100644 index 000000000..fd18d7537 --- /dev/null +++ b/examples/file_progress.py @@ -0,0 +1,16 @@ +from time import sleep +from urllib.request import urlopen + +from rich.progress import wrap_file + +# Read a URL with urlopen +response = urlopen("https://www.textualize.io") +# Get the size from the headers +size = int(response.headers["Content-Length"]) + +# Wrap the response so that it update progress + +with wrap_file(response, size) as file: + for line in file: + print(line.decode("utf-8"), end="") + sleep(0.1) diff --git a/examples/save_table_svg.py b/examples/save_table_svg.py new file mode 100644 index 000000000..e22aee22b --- /dev/null +++ b/examples/save_table_svg.py @@ -0,0 +1,26 @@ +""" +Demonstrates how to export a SVG +""" + +from rich.console import Console +from rich.table import Table + +table = Table(title="Star Wars Movies") + +table.add_column("Released", style="cyan", no_wrap=True) +table.add_column("Title", style="magenta") +table.add_column("Box Office", justify="right", style="green") + +table.add_row("Dec 20, 2019", "Star Wars: The Rise of Skywalker", "$952,110,690") +table.add_row("May 25, 2018", "Solo: A Star Wars Story", "$393,151,347") +table.add_row("Dec 15, 2017", "Star Wars Ep. V111: The Last Jedi", "$1,332,539,889") +table.add_row("Dec 16, 2016", "Rogue One: A Star Wars Story", "$1,332,439,889") + +console = Console(record=True) +console.print(table, justify="center") +console.save_svg("table.svg", title="save_table_svg.py") + +import os +import webbrowser + +webbrowser.open(f"file://{os.path.abspath('table.svg')}") diff --git a/rich/console.py b/rich/console.py index bcacbc738..2cdab4280 100644 --- a/rich/console.py +++ b/rich/console.py @@ -2350,7 +2350,7 @@ def export_svg( ) ) - fragments = [] + fragments: List[str] = [] theme_foreground_color = _theme.foreground_color.hex theme_background_color = _theme.background_color.hex