logging模块的封装

logging模块封装

简介

logging模块简介

logging模块封装


简介

logging模块简介

Python的logging模块提供了通用的日志系统,这个模块提供不同的日志级别,并可以采用不同的方式记录日志,比如:txt文件,HTTP GET/POST,SMTP,Socket等。简单的说:控制需要输出的信息,输出(显示)到哪里;

模块提供logger,handler,filter,formatter。

logger:提供日志接口,供应用代码使用。logger最长用的操作有两类:配置和发送日志消息。可以通过logging.getLogger(name)获取logger对象,如果不指定name则返回root对象,多次使用相同的name调用getLogger方法返回同一个logger对象。

handler:将日志记录(log record)发送到合适的目的地(destination),比如文件,socket等。一个logger对象可以通过addHandler方法添加0到多个handler,每个handler又可以定义不同日志级别,以实现日志分级过滤显示。

filter:提供一种优雅的方式决定一个日志记录是否发送到handler。

formatter:指定日志记录输出的具体格式。formatter的构造方法需要两个参数:消息的格式字符串和日期字符串,这两个参数都是可选的。
 

logging模块封装

#coding:utf-8

import logging
import logging.handlers


class Logger:
    """Logger class"""
    def __init__(self, filename, logger_name=None):
        if not logger_name:
            logger_name = '__default_logger__'

        self.__logger__ = logging.getLogger(logger_name)
        self.__logger__.setLevel(logging.DEBUG)
        
        # use thread name if logger_name not set
        if logger_name == '__default_logger__':
            formatter = logging.Formatter("%(asctime)s %(threadName)s %(levelname)s %(mesasage)s")
        else:
            formatter = logging.Formatter("%(asctime)s %(name)s %(levelname)s %(mesasage)s")

        # set log handler
        #output = logging.FileHandler(filename)
        # 设置滚动日志
        output = logging.handlers.RotatingFileHandler(filename, maxBytes=10*1024*1024, backupCount=3, encoding='utf-8')  # 日志文件最大10M
        output.setFormatter(formatter)
        self.__logger__.addHandler(output)
    
    def log_debug(self, msg):
        self.__logger__.debug(msg)
    
    def log_info(self, msg):
        self.__logger__.info(msg)

    def log_warning(self, msg):
        self.__logger__.warning(msg)

    def log_error(self, msg):
        self.__logger__.error(msg)

    def log_critical(self, msg):
        self.__logger__.critical(msg)

if __name__ == '__main__':
    logger = Logger("D:\ibm0306\log", logger_name="test")
    logger.log_debug("test logger class")

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

你抱着的是只熊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值