1 什么是loguru

github:https://github.com/Delgan/loguru

Loguru是一个轻量级的Python日志记录库,旨在提供一种简单、高效的方式来记录应用程序或脚本的运行情况。它通过简化配置和使用过程,使得开发者能够快速地将日志功能集成到项目中。Loguru支持多种输出格式和目标,包括文件、控制台、电子邮件等,并且允许用户自定义日志级别和样式,以满足不同的记录需求。

2 为什么还要对loguru进行封装

一般的,我们可以这么使用loguru

from loguru import logger

logger.info("hello world!")

我们可以使用以下语句将日志记录到文件中

logger.add("file_1.log", rotation="500 MB")    # Automatically rotate too big file

如果项目只是一个单py文件,所有的逻辑写在一个main.py文件中,使用上面这种方式完全没有问题。

但是在实际的项目中,不会出现一个项目只有一个py文件的情况,我们需要在项目的多个文件中都使用loguru,并将日志输出到同一个日志文件中,所以我们需要基于loguru进一步封装。

3 封装loguru

我们可以通过单例的方式来实现项目中多个文件都可以使用同一个loguru实例,并将日志文件输出到同一个日志文件中。

我们新建一个loguru_logger.py文件,封装代码如下

# -*- coding: utf-8 -*-

import os
from loguru import logger


class Singleton(object):
    def __init__(self, cls):
        self._cls = cls
        self._instance = {}
    def __call__(self):
        if self._cls not in self._instance:
            self._instance[self._cls] = self._cls()
        return self._instance[self._cls]

@Singleton
class LoguruLogger(object):
    def __init__(self):
        current_path = os.path.split(os.path.realpath(__file__))[0]
        self.logger = logger
        self.logger.add(current_path + "/Log/log_{time}.log", enqueue=True, retention="30 days")

    def __call__(self, *args, **kwargs):
        return self.logger

    # @property
    def get_logger(self):
        return self.logger


if __name__ == '__main__':
    LoguruLogger().get_logger().info('a')

在上述代码中,我们构建一个LoguruLogger的单例类,里面将logurulogger作为类的成员变量,并设置了日志文件的路径。

在其它脚本中该如何使用LoguruLogger?

需要先引入LoguruLogger

from utils.loguru_logger import LoguruLogger

然后通过以下方式调用

LoguruLogger().get_logger().info('hello world')

好了,愉快的使用吧。