loguru Python日志神器 | Python 主题月

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: loguru Python日志神器 | Python 主题月

何为 loguru


可能你已经习惯了使用 python 自带的 logging 模块来进行日志处理,我也不例外。但是今天,我要给大家介绍一个全新的日志处理库 loguru


相比 loggingloguru 更加优雅,简单,日志的输出也更加美观。


安装 loguru


pip install loguru
复制代码


demo


代码:


from loguru import logger
logger.debug('this is a debug message')
logger.info('this is another debug message')
logger.warning('this is another debug message')
logger.error('this is another debug message')
logger.info('this is another debug message')
logger.success('this is success message!')
logger.critical('this is critical message!')
复制代码


控制台输出:


网络异常,图片无法展示
|


怎么样,是不是很优雅,loguru 默认以时间,级别,函数名,模块名,行号,信息的顺序来输出日志。


重定向日志到文件


代码:


from loguru import logger
# 配置重定向路径
logger.add('loguru.log')
logger.debug('this is a redirect to file message')
复制代码


控制台输出:


网络异常,图片无法展示
|


日志文件内容:


网络异常,图片无法展示
|


自定义格式


代码:


from loguru import logger
# 配置重定向路径&格式
logger.add('loguru.log',format='{level} {time} {message}')
logger.debug('this is a redirect to file message')
复制代码


控制台输出:


网络异常,图片无法展示
|


日志文件内容:


网络异常,图片无法展示
|


我们可以看到,在 add 中配置的格式只对写入日志文件的内容生效。


日志轮转


用了 loguru 我们还可以非常方便地使用 rotation 配置,比如我们想一天输出一个日志文件,或者文件太大了自动分隔日志文件,我们可以直接使用 add 方法的 rotation 参数进行配置。


按大小轮转


logger.add('runtime_{time}.log', rotation="500 MB")
复制代码


以上配置可以实现每 500M 轮转一次。


按时间轮转


logger.add('runtime_{time}.log', rotation='00:00')
复制代码


以上配置实现了每天 0 点轮转一次。


按周轮转


logger.add('runtime_{time}.log', rotation='1 week')
复制代码


以上配置实现了每周轮转一次。


优雅的异常处理


代码:


from loguru import logger
# 配置重定向路径&格式
logger.add('loguru.log',format='{time} | {level} | {message}')
logger.debug('test traceback')
@logger.catch
def err(x:int,y:int):
    return 1/(x+y)
if __name__ == '__main__':
    err(0,0)
复制代码


控制台输出:


网络异常,图片无法展示
|


日志文件内容:


网络异常,图片无法展示
|


如上,loguru 帮我们指出了异常出现的位置,方便定位问题,而且优雅的展示了异常的日志。

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
17天前
|
Python
python读写操作excel日志
主要是读写操作,创建表格
48 2
|
16天前
|
Python Windows
python知识点100篇系列(24)- 简单强大的日志记录器loguru
【10月更文挑战第11天】Loguru 是一个功能强大的日志记录库,支持日志滚动、压缩、定时删除、高亮和告警等功能。安装简单,使用方便,可通过 `pip install loguru` 快速安装。支持将日志输出到终端或文件,并提供丰富的配置选项,如按时间或大小滚动日志、压缩日志文件等。还支持与邮件通知模块结合,实现邮件告警功能。
python知识点100篇系列(24)- 简单强大的日志记录器loguru
|
1月前
|
数据采集 机器学习/深度学习 存储
使用 Python 清洗日志数据
使用 Python 清洗日志数据
33 2
|
2月前
|
消息中间件 Kafka API
python之kafka日志
python之kafka日志
25 3
|
2月前
|
Python
5-9|Python获取日志
5-9|Python获取日志
|
2月前
|
开发者 Python
基于Python的日志管理与最佳实践
日志是开发和调试过程中的重要工具,然而,如何高效地管理和利用日志常常被忽略。本文通过Python中的logging模块,探讨如何使用日志来进行调试、分析与问题排查,并提出了一些实际应用中的优化建议和最佳实践。
|
2月前
|
Python
Python如何将日志输入到文件里
Python如何将日志输入到文件里
|
2月前
|
Python
python之日志基础班
python之日志基础班
|
3月前
|
运维 监控 数据可视化
自动化运维:使用Python脚本进行日志分析
【8月更文挑战第31天】当系统出现问题时,我们通常会查看日志寻找线索。然而,手动阅读大量日志既费时又易出错。本文将介绍如何使用Python脚本自动分析日志,快速定位问题,提高运维效率。我们将从简单的日志读取开始,逐步深入到复杂的正则表达式匹配和错误统计,最后实现一个自动化的日志监控系统。无论你是新手还是老手,这篇文章都将为你提供有价值的参考。让我们一起探索如何用代码解放双手,让运维工作变得更加轻松吧!
|
1天前
|
Python
不容错过!Python中图的精妙表示与高效遍历策略,提升你的编程艺术感
本文介绍了Python中图的表示方法及遍历策略。图可通过邻接表或邻接矩阵表示,前者节省空间适合稀疏图,后者便于检查连接但占用更多空间。文章详细展示了邻接表和邻接矩阵的实现,并讲解了深度优先搜索(DFS)和广度优先搜索(BFS)的遍历方法,帮助读者掌握图的基本操作和应用技巧。
13 4