Python日志模块logging格式化封装

 

一、前言:

对Python 日志模块logging进行了格式化输出封装,形成自己的日志格式。以后就可以拿来主义了。

1.输出到控制台。

2.输出到当前workspace指定文件。

 

二、代码:

 ##模块[log.py]

import logging
import unittest
import sys


def handleException(excType, excValue, traceback, logger):
    logger.error("Uncaught exception", exc_info=(excType, excValue, traceback))


class Log(object):
    @staticmethod
    def log(tag, message, level=logging.INFO):
        """

        Log messages to console and file(create to current workspace)

        Args:
            tag: message tag
            message: the message
            level(optional): logging level of the message
        """
        logger = Log.get_logger(tag)
        if level == logging.INFO:
            logger.info(message)
        if level == logging.WARNING:
            logger.warning(message)
        if level == logging.DEBUG:
            logger.debug(message)
        if level == logging.CRITICAL:
            logger.critical(message)
        if level == logging.ERROR:
            logger.error(message)

    @staticmethod
    def get_logger(tag):
        """
        Setup the logger
        """
        if len(logging.root.handlers) == 0:
            logging.basicConfig(level=logging.DEBUG,
                                format='%(asctime)s [%(levelname)s][%(name)s]: %(message)s',
                                filename='console.log',
                                filemode='a')
            console = logging.StreamHandler()
            console.setLevel(logging.INFO)
            formatter = logging.Formatter('%(asctime)s [%(levelname)s][%(name)s]: %(message)s')
            console.setFormatter(formatter)
            logging.getLogger('').addHandler(console)
            sys.excepthook = handleException

        return logging.getLogger(tag)

 

三、测试:

from log import Log

Log.log(“tag”,"test  log model~")

 

 尊重劳动成果,转载请注明出处,Thx。

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值