使用python封装log日志文件模块的工具类

导入第三方库

import logging
import logging.handlers

封装工具类

1、创建util.py文件

'''
日志工具类
'''
class Logging:
    def __init__(self):
        # log文件存储路径
        self._log_filename = 'test.log'

        '''
        %(levelno)s: 打印日志级别的数值
        %(levelname)s: 打印日志级别名称
        %(pathname)s: 打印当前执行程序的路径,其实就是sys.argv[0]
        %(filename)s: 打印当前执行程序名
        %(funcName)s: 打印日志的当前函数
        %(lineno)d: 打印日志的当前行号
        %(asctime)s: 打印日志的时间
        %(thread)d: 打印线程ID
        %(threadName)s: 打印线程名称
        %(process)d: 打印进程ID
        %(message)s: 打印日志信息
        '''
        # 日志信息输出格式
        self._formatter = logging.Formatter('%(asctime)s - %(process)d - '
                                            '%(pathname)s - %(levelname)s: %(message)s')
        # 创建一个日志对象
        self._logger = logging.getLogger()
        # 设置控制台日志的输出级别: 级别排序:CRITICAL > ERROR > WARNING > INFO > DEBUG
        self._logger.setLevel(logging.INFO)  # 大于info级别的日志信息都会被输出
        self.set_console_logger()
        self.set_file_logger()

    def set_console_logger(self):
        '''设置控制台日志输出'''
        console_handler = logging.StreamHandler()
        console_handler.setFormatter(self._formatter)
        self._logger.addHandler(console_handler)

    def set_file_logger(self):
        '''设置日志文件输出'''
        formatter = logging.Formatter('%(asctime)s - %(process)d - '
                                      '%(pathname)s - %(levelname)s: %(message)s')
        # 将输出日志信息保存到文件中
        file_handler = logging.handlers.RotatingFileHandler(
            self._log_filename, maxBytes=10485760, backupCount=5, encoding="utf-8")
        file_handler.setFormatter(self._formatter)
        self._logger.addHandler(file_handler)

    def get_logger(self):
        return self._logger


logger = Logging().get_logger()

测试

from util import logger


if __name__ == '__main__':
    logger.info("测试")

测试效果

1、控制台输出

2、日志文件输出

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
可以使用Python内置的logging模块封装一个日志类。下面是一个简单的示例代码: ```python import logging class MyLogger: def __init__(self, name, level=logging.INFO): self.logger = logging.getLogger(name) self.logger.setLevel(level) # 定义日志输出格式 formatter = logging.Formatter('%(asctime)s %(levelname)s %(message)s') # 创建控制台日志处理器 console_handler = logging.StreamHandler() console_handler.setLevel(level) console_handler.setFormatter(formatter) self.logger.addHandler(console_handler) # 创建文件日志处理器 file_handler = logging.FileHandler(filename='mylog.log', mode='a', encoding='utf-8') file_handler.setLevel(level) file_handler.setFormatter(formatter) self.logger.addHandler(file_handler) def debug(self, message): self.logger.debug(message) def info(self, message): self.logger.info(message) def warning(self, message): self.logger.warning(message) def error(self, message): self.logger.error(message) def critical(self, message): self.logger.critical(message) ``` 这个日志类包含了一个构造方法和5个方法,分别对应了不同级别的日志输出。在构造方法中,我们使用logging.getLogger()方法创建了一个Logger对象,并设置了日志级别。然后定义了两个日志处理器,一个是输出到控制台,一个是输出到文件。在每个方法中,我们通过调用Logger对象的不同方法来输出不同级别的日志。这些日志信息将会被输出到控制台和指定的日志文件中。 使用日志类的代码示例如下: ```python logger = MyLogger('mylogger') logger.info('This is an info message') logger.warning('This is a warning message') logger.error('This is an error message') ``` 上述代码将会在控制台和mylog.log文件中输出不同级别的日志信息。通过这种方式,我们可以方便地封装一个可复用的日志类,提高代码的可维护性和可读性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值