百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Python | Loguru一个强大的日志记录模块

off999 2024-11-23 20:48 21 浏览 0 评论

今天给大家介绍一款强大的日志记录工具Loguru,它可以彻底提升你的日志记录体验,而且简单易用。

Loguru日志模块,即插即用具有多种方式滚动日志、自动压缩日志文件、定时删除等功能。此外,多线程安全、日志高亮、日志告警等功能也不是问题。

loguru安装

安装 Loguru 也非常简单,只需在使用pip命令即可

pip install loguru

使用

在 Loguru 中,如果需要将 debug 日志输出到终端,可以执行以下操作:

from loguru import logger
logger.debug("start use loguru")

输出将如下所示:


如果你需要将日志输出到文件,只需执行以下操作:

from loguru import logger
logger.add("file_{time}.log")
logger.debug("start use loguru")

这会在当前运行的文件夹中生成一个file_current time.log的日志文件,如下图所示:

处理程序/格式化程序/过滤器?

如何添加处理程序?如何设置日志格式?如何过滤消息?如何设置日志级别?在 Loguru 中,所有这些配置都可以一次性完成。

logger.add(sys.stderr, format="{time} {level} {message}", 
           filter="my_module", level="INFO")

滚动日志和压缩

使用 Loguru,你可以轻松实现滚动日志。

  • 按时间滚动

比如按时间滚动,只需要在参数中添加一个rotation参数即可logger.add

from loguru import logger
logger.add("file_2.log", rotation="12:00") # Create new file at 12AM
logger.debug("start use loguru")

这样,如果当前时间超过了这个设定的时间,就会生成一个新的日志文件。如果不是这个时间就会使用原始日志文件。

  • 按大小滚动

除了按时间滚动日志,Loguru 还可以按日志大小滚动:

from loguru import logger
logger.add("file_1.log", rotation="1 MB")
logger.debug("start use loguru")

这样,一旦日志文件大小超过1MB,就会生成一个新的日志文件。

  • 压缩日志

如果不想删除原来的日志文件,Loguru也支持直接压缩日志:

from loguru import logger
logger.add("file_Y.log", compression="zip")

其它功能

  • 自定义颜色

Loguru 支持自定义颜色,如果你不喜欢它的默认颜色,你可以这样改:

logger.add(sys.stdout,
           colorize=True, 
           format="<green>{time}</green> <level>{message}</level>")

像 HTML 标签 <green></green> 标签这样的文本会被标记为绿色。

  • 多进程安全

Loguru 默认是线程安全的,但不是多进程安全的。但是如果你需要多进程/异步日志记录,它也支持,只需要添加一个enqueue参数:

logger.add("somefile.log", enqueue=True)
  • 回溯支持

至于日志,没有错误堆栈的日志是没有灵魂的。Loguru 允许你显示整个堆栈信息以帮助你发现问题(包括变量)。例如:

logger.add("out.log", backtrace=True, diagnose=True)
def func(a, b):
    return a / b

def nested(c):
    try:
        func(5, c)
    except ZeroDivisionError:
        logger.exception("What?!")

nested(0)

日志将是这样的,你可以看到它非常清楚地显示了错误的地方。

  • 电子邮件提醒

Loguru 可以与强大notifiers的电子邮件通知模块库结合使用,以在程序意外失败时接收电子邮件,或发送许多其他类型的通知。

import notifiers

params = {
    "username": "you@mail.com",
    "password": "abc123",
    "to": "dest@mail.com"
}

notifier = notifiers.get_notifier("mail")
notifier.notify(message="The application is running!", **params)

# Be alerted on each error message
from notifiers.logging import NotificationHandler

handler = NotificationHandler("mail", defaults=params)
logger.add(handler, level="ERROR")

这样配置后,每次产生Error日志时,程序都会自动发送一个alert到你的邮箱,真是方便。

除了这些特性,Loguru 还支持兼容 Python 原生的 Logging 模块,你可以将原来标准 logger 记录的所有信息都转移到 Loguru 中。

如果你发现我的任何文章对你有帮助或者有用,麻烦点赞或者转发。 谢谢!

相关推荐

手机cpu排名一览表(手机cpu排名前十)

第一名:苹果:A151、A15Bionic采用4颗效率核心+2颗性能核心的组合,搭配4核心GPU,集成85亿个晶体管,性能提升了大约20%。2、苹果称其为“智能手机中最快的CPU”,有着“智能手机...

系统补丁怎么安装(系统补丁在哪)

1成后,需要打sp1补丁,不过微软对win7的支持已经结束了,建议升级新系统2到微软官网/zh-cn/download找到win7系统版本的补丁,点击下载3勾选对应系统版本4确认无误后,点击Next5...

win10命令行窗口怎么打开(window10命令行窗口)

调出运行命令的方法如下1:同时按下win+R,在打开的运行对话框中输入:cmd后,回车打开。2:也可以在同时按下win+x,或者“开始”菜单上右键,在弹出菜单上选择“命令行提示符”或“命令提示符(管理...

windows7屏幕亮度怎么调整(windows7屏幕亮度调节)

windows7屏幕亮度调节方法如下1.鼠标右键桌面空白处,在弹出的菜单中选择【个性化】。2.进入属性界面,选择左下角的【显示】选项。3.在弹出的显示页面右侧点击【调整亮度】。4.进入调整亮度页面,下...

永久删除的视频怎么找回(怎么恢复永久删除的视频)
  • 永久删除的视频怎么找回(怎么恢复永久删除的视频)
  • 永久删除的视频怎么找回(怎么恢复永久删除的视频)
  • 永久删除的视频怎么找回(怎么恢复永久删除的视频)
  • 永久删除的视频怎么找回(怎么恢复永久删除的视频)
xpsp2系统下载地址(windows xp sp2 iso)

WindowsXPProfessionalSP2产品密钥是微软公司的一个软件密钥,用于授权用户使用该软件的完整功能。它通常与产品许可证一起使用,用于确保软件的合法性和安全性。使用Windows...

开机microsoft登录不上

1、系统问题:如果系统版本比较低,可能会由于旧系统存在某些BUG未修复或业务功能未优化,使手机在使用APP等应用过程中出现卡的情况,建议更新到最新的ios系统使用。2、内存问题:如果内存比较小,在运行...

如何取消win10开机密码(如何取消win10开机密码账户登录)

取消Windows10的开机密码可以通过以下方法进行操作:方法一:使用用户账户设置1.打开“开始”菜单,点击“设置”图标。2.在设置窗口中,点击“帐户”选项。3.在左侧菜单中,选择“登录选项”。4....

免费解压文件的软件(免费解压文件的软件电脑)

1、快压快压(kuaizip)是一款非常流氓的压缩和解压缩软件,一款免费、方便、快速的压缩和解压缩利器,拥有一流的压缩技术,是国内第一款具备自主压缩格式的软件。快压自身的压缩格式KZ具有超大的压缩比和...

无线usb网卡插上去没有反应(为什么usb无线网卡插上去没反应)

当出现电脑无法识别无线网卡的情况时,是简单的方法就是将无线USB网卡插到电脑后置USB接口上,以保证供电的充足。当然如果是偶然出现无法识别的情况,建议重启一下电脑试试。启用USB无线网卡驱动:右击“计...

怎么登录自己家的路由器(怎么登录自己家的路由器账号)

登陆家里的路由器方法:1、先查看ip,方法:win+r---输入:cmd---在再黑白界面输入:ipconfig,按回车。2、根据网关查看路由器地址。若网关是:192.168.2.1,那么路由器的ip...

linux操作系统安装步骤(linux系统详细安装步骤)

1.选择“中文(简体)”,然后点击“安装Ubuntu”。2.点击“继续”。3.然后点击“现在安装”。4.选择地址的时区,然后点击“继续”。5.选择“汉语”,然后点击“继续”。6.输入用户的名字。7.设...

苹果手机怎么设置定时关机(苹果手机怎么设置定时关机重启)

苹果手机可以设置定时关机,但无法设置定时开机。具体操作步骤如下:进入苹果手机自带的时钟。点击屏幕有下角的计时器。点击画面中间的计时结束启用选项。选择画面最下方的“停止播放”。之后再点击画面右上角的设定...

无线网wifi密码忘记了怎么办

忘记wifi密码后,可以在路由器后台查看。1.在浏览器的地址栏中,输入路由器上的管理地址,进入后台界面;2.在后台界面里,找到“无线设置”选项,点击它;3.在新界面里,点击wifi密码右侧的小眼睛图标...

win7系统无法正常开机怎么办
win7系统无法正常开机怎么办

解决方法如下1,出现无法启动的原因,要注意是开机启动不了,还是在进度条那里缓冲,过不去.如果是开机启动不了,那就要看一下内存条、电源等有没有问题?如果是在进度条那里,那就看下方的三种方法。2,第一种方法:1,开机按F8键.2,选择最近一次的...

2025-11-16 07:51 off999

取消回复欢迎 发表评论: