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
的单例类,里面将loguru
的logger
作为类的成员变量,并设置了日志文件的路径。
在其它脚本中该如何使用LoguruLogger?
需要先引入LoguruLogger
from utils.loguru_logger import LoguruLogger
然后通过以下方式调用
LoguruLogger().get_logger().info('hello world')
好了,愉快的使用吧。
本文作者:StubbornHuang
版权声明:本文为站长原创文章,如果转载请注明原文链接!
原文标题:Python – 基于loguru封装实际项目可用的日志输出类
原文链接:https://www.stubbornhuang.com/3022/
发布于:2024年03月29日 11:04:05
修改于:2024年03月29日 11:04:05
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
评论
52