Skip to main content

Wrapper for the Python logging formatter that adds color.

Project description

Chroma Formatter

License: MIT Code style: black PyPI version Code Coverage

Wrapper for Python logging formatter that adds color

Demo

Installation

Chroma Formatter is on PyPI and can be installed with:

pip install chromaformatter

Usage

Chroma Formatter adds two features to the default logging formatter, colors can be added to the log format string, and formatted arguments in a log message can be colored. Colors can be inserted info the format string as such:

log_format = (
    f'{Colors.Fore.GREEN}%(asctime)-s '
    f'{Colors.LEVEL_COLOR}%(levelname).1s '
    f'{Colors.Fore.MAGENTA}%(filename)-s:%(lineno)03d '
    f'{Colors.LEVEL_COLOR}- %(message)s'
)

Then, use chromaformatter.ChromaFormatter rather than logging.Formatter.

import sys
import logging

from chromaformatter import ChromaFormatter, Colors

log = logging.getLogger()
log_format = (
    f'{Colors.Fore.GREEN}%(asctime)-s '
    f'{Colors.LEVEL_COLOR}%(levelname).1s '
    f'{Colors.Fore.MAGENTA}%(filename)-s:%(lineno)03d '
    f'{Colors.LEVEL_COLOR}- %(message)s'
)
formatter = ChromaFormatter(
    fmt=log_format,
    arg_start_color=Colors.Fore.WHITE,
    arg_end_color=Colors.LEVEL_COLOR
)
handler = logging.StreamHandler(stream=sys.stdout)
handler.setFormatter(formatter)
log.addHandler(handler)

Formatted Arguments in a Log

By setting arg_start_color for argument colors and arg_end_color for the rest of the string that comes after the argument, those colors will be applied to arguments.

log.info('This %s will be colored.', 'variable')

Additional Configuration

ChromaFormatter has a dict called color_map to determine the colors of each logging level.

By default, the colors are:

Category Color
NOTSET Fore.LIGHTBLUE_EX
DEBUG Fore.BLUE
INFO Fore.Cyan
WARNING Fore.YELLOW
ERROR Fore.LIGHTRED_EX
CRITICAL Fore.RED
ARGS Fore.White

Color map can be changed as such:

formatter.color_map[logging.INFO] = Colors.Fore.WHITE
formatter.color_map[logging.DEBUG] = Colors.Fore.MAGENTA

Applying to Existing Loggers

If you are using a third party module that uses the standard python logging module you can apply a ChromaFormatter as such:

import sys
import logging

from chromaformatter import ChromaFormatter, Colors

log_format = (
    f'{Colors.Fore.GREEN}%(asctime)-s '
    f'{Colors.LEVEL_COLOR}%(levelname).1s '
    f'{Colors.Fore.MAGENTA}%(filename)-s:%(lineno)03d '
    f'{Colors.LEVEL_COLOR}- %(message)s'
)
stream_formatter = ChromaFormatter(log_format)
stream_handler = logging.StreamHandler(stream=sys.stdout)

flask_logger = logging.getLogger('werkzeug')
while flask_logger.handlers:
    flask_logger.removeHandler(flask_logger.handlers.pop())
flask_logger.addHandler(stream_handler)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

chromaformatter-6.0.0.tar.gz (4.4 kB view details)

Uploaded Source

Built Distribution

chromaformatter-6.0.0-py3-none-any.whl (4.3 kB view details)

Uploaded Python 3

File details

Details for the file chromaformatter-6.0.0.tar.gz.

File metadata

  • Download URL: chromaformatter-6.0.0.tar.gz
  • Upload date:
  • Size: 4.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.13 CPython/3.10.6 Linux/6.2.0-76060200-generic

File hashes

Hashes for chromaformatter-6.0.0.tar.gz
Algorithm Hash digest
SHA256 deb6a8c83c9a065efb13c1986978644afd562f01db9a867d638d61f0cadd0aed
MD5 3e8de0f9dfac194acc4a22aef5becbfb
BLAKE2b-256 b3f4f3d8afa1fa46c14c120dc0af885ac307090f844276b30aeb1dcb95f2f623

See more details on using hashes here.

File details

Details for the file chromaformatter-6.0.0-py3-none-any.whl.

File metadata

  • Download URL: chromaformatter-6.0.0-py3-none-any.whl
  • Upload date:
  • Size: 4.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.13 CPython/3.10.6 Linux/6.2.0-76060200-generic

File hashes

Hashes for chromaformatter-6.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 85fd0077dd7891b116ea47da677da6654f92f3eb0bec199c27f35cdac1f83a82
MD5 e7c2b87e234570e22556b9a000104417
BLAKE2b-256 45002bd66d95760fda5bb8e22677fe0ddf56a197a35eeb98c536fe5a30d873ad

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page