logger.py 1.7 KB
Newer Older
1
import datetime
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
import logging

import termcolor

from . import __appname__


COLORS = {
    'WARNING': 'yellow',
    'INFO': 'white',
    'DEBUG': 'blue',
    'CRITICAL': 'red',
    'ERROR': 'red',
}


class ColoredFormatter(logging.Formatter):

20 21
    def __init__(self, fmt, use_color=True):
        logging.Formatter.__init__(self, fmt)
22 23 24 25 26
        self.use_color = use_color

    def format(self, record):
        levelname = record.levelname
        if self.use_color and levelname in COLORS:
27 28 29 30 31 32 33 34

            def colored(text):
                return termcolor.colored(
                    text,
                    color=COLORS[levelname],
                    attrs={'bold': True},
                )

K
Kentaro Wada 已提交
35
            record.levelname2 = colored('{:<7}'.format(record.levelname))
36 37 38 39 40 41 42 43
            record.message2 = colored(record.msg)

            asctime2 = datetime.datetime.fromtimestamp(record.created)
            record.asctime2 = termcolor.colored(asctime2, color='green')

            record.module2 = termcolor.colored(record.module, color='cyan')
            record.funcName2 = termcolor.colored(record.funcName, color='cyan')
            record.lineno2 = termcolor.colored(record.lineno, color='cyan')
44 45 46 47 48
        return logging.Formatter.format(self, record)


class ColoredLogger(logging.Logger):

49
    FORMAT = (
K
Kentaro Wada 已提交
50
        '[%(levelname2)s] %(module2)s:%(funcName2)s:%(lineno2)s - %(message2)s'
51
    )
52 53 54 55 56 57 58 59 60 61 62 63 64 65 66

    def __init__(self, name):
        logging.Logger.__init__(self, name, logging.INFO)

        color_formatter = ColoredFormatter(self.FORMAT)

        console = logging.StreamHandler()
        console.setFormatter(color_formatter)

        self.addHandler(console)
        return


logging.setLoggerClass(ColoredLogger)
logger = logging.getLogger(__appname__)