logger.py 2.42 KB
Newer Older
fanxun committed
1 2 3 4
# _*_ coding:utf-8 _*_
__author__ = 'fanxun'
__data__ = "2021-05-10 15:47"

fanxun committed
5
import os, time
fanxun committed
6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29
import logging
from logging.handlers import TimedRotatingFileHandler
from config import BaseConfig

# 日志级别
CRITICAL = 50
FATAL = CRITICAL
ERROR = 40
WARNING = 30
WARN = WARNING
INFO = 20
DEBUG = 10
NOTSET = 0

LOG_PATH = BaseConfig.log_path

class LogHandler(logging.Logger):
    """
    日志处理
    """
    def __init__(self, name, level=DEBUG, stream=True, file=True):
        self.name = name
        self.level = level
        logging.Logger.__init__(self, self.name, level=level)
30
        self.__determine_folder()
fanxun committed
31 32 33 34 35
        if stream:
            self.__setStreamHandler__()
        if file:
            self.__setFileHandler__()

36 37 38 39 40
    def __determine_folder(self):
        """判断日志路径是否存在"""
        if not os.path.exists(LOG_PATH):
            os.mkdir(LOG_PATH)

fanxun committed
41 42 43 44
    def __setFileHandler__(self, level=None):
        """
        输出到文件
        """
fanxun committed
45
        file_name = os.path.join(LOG_PATH, f'{self.name}{time.strftime(r"%Y%m%d%H%M%S", time.localtime())}.log')
46 47
        # 设置日志回滚, 保存在log目录, 一天保存一个文件, 保留7天
        file_handler = TimedRotatingFileHandler(filename=file_name, when='D', interval=1, backupCount=7)
fanxun committed
48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77
        file_handler.suffix = '%Y%m%d.log'
        if not level:
            file_handler.setLevel(self.level)
        else:
            file_handler.setLevel(level)
        formatter = logging.Formatter('%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s')

        file_handler.setFormatter(formatter)
        self.file_handler = file_handler
        self.addHandler(file_handler)

    def __setStreamHandler__(self, level=None):
        """
        输出到控制台
        """
        stream_handler = logging.StreamHandler()
        formatter = logging.Formatter('%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s')
        stream_handler.setFormatter(formatter)
        if not level:
            stream_handler.setLevel(self.level)
        else:
            stream_handler.setLevel(level)
        self.addHandler(stream_handler)

    def resetName(self, name):
        self.name = name
        self.removeHandler(self.file_handler)
        self.__setFileHandler__()


fanxun committed
78 79 80
logger = LogHandler('log')


fanxun committed
81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125
if __name__ == '__main__':
    log = LogHandler('test')
    log.info('this is a test msg')
    log.error('hoo')