Simple, powerful, and fast logging for Python. https://www.structlog.org/
Find a file
2026-03-04 06:47:47 +01:00
.github docs: use public LWN link 2026-03-04 06:47:47 +01:00
docs Actually update 2026-02-10 17:43:17 +01:00
src/structlog dev: don't raise warning on rendered exceptions (#790) 2026-03-04 06:46:42 +01:00
tests dev: don't raise warning on rendered exceptions (#790) 2026-03-04 06:46:42 +01:00
.git_archival.txt Better reproducibility 2024-08-24 08:15:12 +02:00
.gitattributes Enable support for git archive installs 2023-02-02 08:09:55 +01:00
.gitignore quote str value with special char in dev output (#649) 2024-09-18 11:17:44 +00:00
.pre-commit-config.yaml [pre-commit.ci] pre-commit autoupdate (#792) 2026-03-03 07:12:25 +01:00
.python-version-default Use 3.13 in dev 2024-10-12 15:14:34 +02:00
.readthedocs.yaml Only build in RTD and only doctests in CI (#691) 2025-01-16 10:35:26 +01:00
CHANGELOG.md dev: don't raise warning on rendered exceptions (#790) 2026-03-04 06:46:42 +01:00
COPYRIGHT Steal Rust's dual-license handling again 2022-07-20 12:09:15 +02:00
LICENSE-APACHE Steal Rust's dual-license handling again 2022-07-20 12:09:15 +02:00
LICENSE-MIT Steal Rust's dual-license handling again 2022-07-20 12:09:15 +02:00
NOTICE Steal Rust's dual-license handling again 2022-07-20 12:09:15 +02:00
pyproject.toml sponsors: update URL 2026-02-10 17:41:53 +01:00
README.md Add AI policy 2026-02-23 16:10:33 +01:00
show_off.py Update demo screenshot 2025-10-14 09:32:56 +02:00
tox.ini tox: use version ranges 2026-01-06 06:08:14 +01:00

structlog: Structured Logging for Python

structlog: Structured Logging for Python

Documentation License: MIT / Apache 2.0 No AI slop inside. DOI Supported Python versions of the current PyPI release. Downloads per month

Simple. Powerful. Fast. Pick three.

structlog is the production-ready logging solution for Python:

  • Simple: Everything is about functions that take and return dictionaries all hidden behind familiar APIs.
  • Powerful: Functions and dictionaries arent just simple but also powerful. structlog leaves you in control.
  • Fast: structlog is not hamstrung by designs of yore. Its flexibility comes not at the price of performance.

Thanks to its flexible design, you choose whether you want structlog to take care of the output of your log entries or whether you prefer to forward them to an existing logging system like the standard library's logging module.

The output format is just as flexible and structlog comes with support for JSON, logfmt, as well as pretty console output out-of-the-box:

Screenshot of colorful structlog output with ConsoleRenderer

Sponsors

structlog would not be possible without our amazing sponsors. Especially those generously supporting us at the The Organization tier and higher:

Please consider joining them to help make structlogs maintenance more sustainable!

Introduction

structlog has been successfully used in production at every scale since 2013, while embracing cutting-edge technologies like asyncio, context variables, or type hints as they emerged. Its paradigms proved influential enough to help design structured logging packages across ecosystems.

A short explanation on why structured logging is good for you, and why structlog is the right tool for the job can be found in the Why chapter of our documentation.

Once you feel inspired to try it out, check out our friendly Getting Started tutorial.

For a fully-fledged zero-to-hero tutorial, check out A Comprehensive Guide to Python Logging with structlog.

If you prefer videos over reading, check out Markus Holtermann's talk Logging Rethought 2: The Actions of Frank Taylor Jr.:

Credits

structlog is written and maintained by Hynek Schlawack. The idea of bound loggers is inspired by previous work by Jean-Paul Calderone and David Reid.

The development is kindly supported by my employer Variomedia AG, structlogs Tidelift subscribers, and all my amazing GitHub Sponsors.

The logs-loving beaver logo has been contributed by Lynn Root.

structlog for Enterprise

Available as part of the Tidelift Subscription.

The maintainers of structlog and thousands of other packages are working with Tidelift to deliver commercial support and maintenance for the open source packages you use to build your applications. Save time, reduce risk, and improve code health, while paying the maintainers of the exact packages you use.