美文网首页python实用小公举爬虫(Mac)
Loguru:优雅的Python程序日志

Loguru:优雅的Python程序日志

作者: SeanCheney | 来源:发表于2020-07-17 10:24 被阅读0次

习惯了使用Python自带的logging模块记录日志,但是总觉得不够优雅。
Loguru解决了这个问题。guru是印度语中大师的意思,直译就是“日志大师”。

使用pip安装

pip install loguru

开箱即用

不同的日志等级,输出效果也不一样(等级由低到高是DEBUGINFOWARNINGERRORCRITICAL

logger.debug("That's it, beautiful and simple logging!")
logger.info("That's it, beautiful and simple logging!")
logger.warning("That's it, beautiful and simple logging!")
logger.error("That's it, beautiful and simple logging!")
logger.critical("That's it, beautiful and simple logging!")

统一的add()函数

add()函数用于注册“沉量”sink,用于管理日志消息。

logger.add(sink='log.txt', format="{time} {level} {message}", filter="my_module", level="INFO")

将上面两个功能合起来,就能实现最基本的日志功能了。

from loguru import logger

logger.add(sink='log.log', format="{time} - {level} - {message}", level="INFO")
logger.info("That's it, beautiful and simple logging!")

可以用rotationretentioncompression进行日志窗口、更新、压缩管理。

logger.add("file_1.log", rotation="500 MB")    # 日志文件的窗口大小是500M
logger.add("file_2.log", rotation="12:00")     # 每天中午12点创建新日志文件
logger.add("file_3.log", rotation="1 week")    # 自动更新旧文件
logger.add("file_X.log", retention="10 days")  # 清理旧文件
logger.add("file_Y.log", compression="zip")    # 压缩文件

loguru支持f-string

logger.info("If you're using Python {}, prefer {feature} of course!", 3.6, feature="f-strings")

Loguru支持在主进程和线程中捕获异常,使用@logger.catch

from loguru import logger

logger.add(sink='log.log', format="{time} - {level} - {message}", level="INFO")

@logger.catch
def my_function(x, y, z):
    return 1 / (x + y + z)

res = my_function(0,0,0)
print(res)

修改日志文字的颜色

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

使用enqueue,可以保证多线程安全、多进程安全

logger.add("somefile.log", enqueue=True)

详细的异常回溯

使用backtracediagnose

from loguru import logger

logger.add("output.log", backtrace=True, diagnose=True)  # 设置为'False'可以保证生产中不泄露信息

def func(a, b):
    return a / b

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

nested(0)

修改时间格式

logger.add("file.log", format="{time:YYYY-MM-DD at HH:mm:ss} | {level} | {message}")

参考:
https://github.com/Delgan/loguru
https://loguru.readthedocs.io/en/stable/overview.html

相关文章

  • Loguru:优雅的Python程序日志

    习惯了使用Python自带的logging模块记录日志,但是总觉得不够优雅。Loguru解决了这个问题。guru是...

  • loguru

    C++日志模块 loguru loguru一共只需要两个源文件: loguru.hpp 和 loguru.cpp....

  • 更优美的python日志管理库Loguru

    一、Loguru简介 Loguru的主旨就是让程序员能方便优美的实现日志记录。您还记得配置记录器的繁琐过程吗?因为...

  • Python 如何更优雅的记录日志(loguru)

    一、背景 在使用Python 编写自动化脚本过程中,大多数情况下可能都是直接用 logging 模块来记录日志,在...

  • Python日志处理loguru

    python内置logging需要配置繁琐的信息,loguru更加简洁而且内置了日志显示格式,其使用了better...

  • python优雅写日志

    前言 最近研究了下新的日志管理方案库,发觉loguru库不错,推荐给大家。 安装loguru 入门 日志的级别 日...

  • Python日志工具 loguru

    错误级别 level nameSeverity valueLogger methodTRACE5logger.tr...

  • python loguru 日志按天分割

    loguru日志配置 目的 实现同时控制台和文件输出,并且文件按天分割 原因 使用loguru原因,官方loggi...

  • Loguru:Python 日志终极解决方案

    日志的重要性 日志的作用非常重要,日志可以记录用户的操作、程序的异常,还可以为数据分析提供依据,日志的存在意义就是...

  • 使用loguru记录日志

    前面我们学习了Python的日志模块,发现想要使用不是开箱即用,而是需要进行一系列的配置。那么,有咩有直接开箱即用...

网友评论

    本文标题:Loguru:优雅的Python程序日志

    本文链接:https://www.haomeiwen.com/subject/fcwmhktx.html