summaryrefslogtreecommitdiffstats
path: root/docs/source/logging.rst
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-14 20:18:28 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-14 20:18:28 +0000
commitf8363b456f1ab31ee56abad579b215af195093d5 (patch)
treeb1500c675c2e0a55fb75721a854e1510acf7c862 /docs/source/logging.rst
parentInitial commit. (diff)
downloadrich-f8363b456f1ab31ee56abad579b215af195093d5.tar.xz
rich-f8363b456f1ab31ee56abad579b215af195093d5.zip
Adding upstream version 9.11.0.upstream/9.11.0upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'docs/source/logging.rst')
-rw-r--r--docs/source/logging.rst47
1 files changed, 47 insertions, 0 deletions
diff --git a/docs/source/logging.rst b/docs/source/logging.rst
new file mode 100644
index 0000000..b907718
--- /dev/null
+++ b/docs/source/logging.rst
@@ -0,0 +1,47 @@
+Logging Handler
+===============
+
+Rich supplies a :ref:`logging handler<logging>` which will format and colorize text written by Python's logging module.
+
+Here's an example of how to set up a rich logger::
+
+ import logging
+ from rich.logging import RichHandler
+
+ FORMAT = "%(message)s"
+ logging.basicConfig(
+ level="NOTSET", format=FORMAT, datefmt="[%X]", handlers=[RichHandler()]
+ )
+
+ log = logging.getLogger("rich")
+ log.info("Hello, World!")
+
+Rich logs won't render :ref:`console_markup` in logging by default as most libraries won't be aware of the need to escape literal square brackets, but you can enable it by setting ``markup=True`` on the handler. Alternatively you can enable it per log message by supplying the ``extra`` argument as follows::
+
+ log.error("[bold red blink]Server is shutting down![/]", extra={"markup": True})
+
+
+Handle exceptions
+-------------------
+
+The :class:`~rich.logging.RichHandler` class may be configured to use Rich's :class:`~rich.traceback.Traceback` class to format exceptions, which provides more context than a builtin exception. To get beautiful exceptions in your logs set ``rich_tracebacks=True`` on the handler constructor::
+
+
+ import logging
+ from rich.logging import RichHandler
+
+ logging.basicConfig(
+ level="NOTSET",
+ format="%(message)s",
+ datefmt="[%X]",
+ handlers=[RichHandler(rich_tracebacks=True)]
+ )
+
+ log = logging.getLogger("rich")
+ try:
+ print(1 / 0)
+ except Exception:
+ log.exception("unable print!")
+
+
+There are a number of other options you can use to configure logging output, see the :class:`~rich.logging.RichHandler` reference for details.