Skip to content

handlers

ColoredConsoleHandler

Bases: StreamHandler

same as StreamHandler but with colored output based on the logging-level of each message

Source code in src/loggext/handlers/colored.py
class ColoredConsoleHandler(logging.StreamHandler):
    r"""
    same as `StreamHandler` but with colored output based on the logging-level of each message
    """
    STDOUT = sys.stdout
    STDERR = sys.stderr

    def format(self, record):
        colorcode = COLOR_MAP.get(record.levelno)
        msg = super().format(record)
        if colorcode is None:
            return msg
        return f"{colorcode}{msg}{ENDCOLOR}"

LevelColoredConsoleHandler

Bases: StreamHandler

similar to ColoredConsoleHandler but colors only the levelname

Source code in src/loggext/handlers/colored.py
class LevelColoredConsoleHandler(logging.StreamHandler):
    r"""
    similar to `ColoredConsoleHandler` but colors only the levelname
    """
    STDOUT = sys.stdout
    STDERR = sys.stderr

    def emit(self, record):
        colorcode = COLOR_MAP.get(record.levelno)
        if colorcode is not None:
            record = logging.makeLogRecord(record.__dict__)  # copy to not modify for other logging-handlers
            record.levelname = f"{colorcode}{record.levelname}{ENDCOLOR}"
        super().emit(record)