一日一技:更优雅地在 Python 中写日志

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: 一日一技:更优雅地在 Python 中写日志

摄影:产品经理买单:kingname

原来我们在 Python 中写日志,使用的是 Python 自带的 logging 模块,要实现既在终端输出,又能写文件,并且日志文件还能 rotate ,代码需要十多行:

import logging
from logging.handlers import RotatingFileHandler
os.makedirs('Logs', exists_ok=True)
logger = logging.getLogger('Robot')
handler = logging.StreamHandler()
handler.setLevel(logging.DEBUG)
file_handler = RotatingFileHandler(os.path.join('Logs', 'robot.log'),
maxBytes=5 * 1024 * 1024,
backupCount=10,
encoding='utf-8')
formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
handler.setFormatter(formatter)
file_handler.setFormatter(formatter)
logger.addHandler(handler)
logger.addHandler(file_handler)
logger.setLevel(logging.DEBUG)
logger.info('终于可以写日志了...')

那有没有什么简单好用,for human的写日志方案呢?

当然有,那就是使用loguru[1]这个模块。

它有多好用呢?我们用一段代码来演示:

from loguru import logger
logger.add('logs/z_project.log',
           level='DEBUG',
           format='{time:YYYY-MM-DD HH:mm:ss} - {level} - {file} - {line} - {message}',
           rotation="10 MB")
logger.info('可以写日志了')

不需要提前创建文件夹。不需要设置奇奇怪怪的handler

甚至你可以直接把它当做装饰器使用,当一个函数报错的时候,自动记录日志:

from loguru import logger
@logger.catch
def test():
    'a' + 1

函数报错时,自动记录报错信息到日志中。

他记录的报错信息有多准确呢?我们来看这个图:

每个变量的值都给你标出来了。

使用 loguru 也只需要定义一次格式。只需要在入口文件定义好格式,在同一个项目中的其他文件中,直接

from loguru import logger
logger.info('可以用了')
相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
目录
相关文章
|
2月前
|
监控 数据挖掘 数据安全/隐私保护
Python脚本:自动化下载视频的日志记录
Python脚本:自动化下载视频的日志记录
|
3月前
|
Python
python读写操作excel日志
主要是读写操作,创建表格
72 2
|
3月前
|
Python Windows
python知识点100篇系列(24)- 简单强大的日志记录器loguru
【10月更文挑战第11天】Loguru 是一个功能强大的日志记录库,支持日志滚动、压缩、定时删除、高亮和告警等功能。安装简单,使用方便,可通过 `pip install loguru` 快速安装。支持将日志输出到终端或文件,并提供丰富的配置选项,如按时间或大小滚动日志、压缩日志文件等。还支持与邮件通知模块结合,实现邮件告警功能。
python知识点100篇系列(24)- 简单强大的日志记录器loguru
|
3月前
|
数据采集 机器学习/深度学习 存储
使用 Python 清洗日志数据
使用 Python 清洗日志数据
52 2
|
4月前
|
消息中间件 Kafka API
python之kafka日志
python之kafka日志
44 3
|
4月前
|
Python
5-9|Python获取日志
5-9|Python获取日志
|
4月前
|
开发者 Python
基于Python的日志管理与最佳实践
日志是开发和调试过程中的重要工具,然而,如何高效地管理和利用日志常常被忽略。本文通过Python中的logging模块,探讨如何使用日志来进行调试、分析与问题排查,并提出了一些实际应用中的优化建议和最佳实践。
|
5月前
|
消息中间件 安全 Python
Python日志管理之Loguru
Python日志管理之Loguru
|
4月前
|
Python
Python如何将日志输入到文件里
Python如何将日志输入到文件里
|
4月前
|
Python
python之日志基础班
python之日志基础班
下一篇
开通oss服务