Python中的logger作用(from loguru import logger)

文章目录

      • 具体解释
      • 示例代码
      • 为什么使用 Loguru?
      • 常见使用场景
      • 总结

Loguru 是一个非常流行且易用的 Python 日志记录库, logger 是其主要的日志记录工具,用来记录程序运行中的信息,如调试信息、错误信息、运行状态等。


具体解释

  1. Loguru 库的作用:

    • Loguru 是一个功能强大、易用性高的日志记录库(类似于 Python 标准库中的 logging 模块)。
    • 它提供了简洁的 API,便于快速集成日志记录功能,尤其适合初学者和中小型项目。
  2. logger 对象的作用:

    • logger 是 Loguru 提供的默认的日志记录实例,可以直接使用 logger 来输出日志。
    • 它包含了一系列方法(如 info()debug()warning() 等),用于记录不同级别的日志信息。
  3. from loguru import logger 的意义:

    • 这句代码从 Loguru 库中导入了 logger 对象,之后我们可以直接使用 logger 来记录日志,而无需额外配置。

示例代码

以下是一个用 logger 的简单日志记录示例:

from loguru import logger# 输出一般信息
logger.info("程序开始运行")# 输出调试信息
logger.debug("这是一条调试信息")# 输出警告信息
logger.warning("这是一个警告")# 输出错误信息
logger.error("出错了!")

运行结果:

2023-11-06 12:00:00.000 | INFO     | __main__:<module>:3 - 程序开始运行
2023-11-06 12:00:00.001 | DEBUG    | __main__:<module>:6 - 这是一条调试信息
2023-11-06 12:00:00.002 | WARNING  | __main__:<module>:9 - 这是一个警告
2023-11-06 12:00:00.003 | ERROR    | __main__:<module>:12 - 出错了!

为什么使用 Loguru?

与标准库的 logging 模块相比,Loguru 提供了一些显著的优势:

  1. 易用性:

    • 不需要复杂的配置文件。
    • 开箱即用,直接导入 logger 即可记录日志。
  2. 丰富的日志格式:

    • 日志信息默认包含时间戳、日志级别、文件名、行号等。
    • 支持自定义日志格式,并且可以轻松定制输出格式。
  3. 支持多种输出:

    • 日志可以输出到控制台、文件,甚至其他外部服务。
    • 例如,日志可以同时写入控制台和文件:
      logger.add("app.log", level="INFO")  # 将 INFO 级别及以上的日志写入文件
      logger.info("日志输出到控制台和文件")
      
  4. 支持异步和线程安全:

    • Loguru 自动支持异步日志记录,且在多线程环境中表现良好。
  5. 功能强大的特性:

    • 支持日志过滤、日志旋转(按大小或时间分割日志文件)、日志压缩等。

常见使用场景

  1. 记录调试信息和程序状态:

    • 开发阶段用 logger.debug()logger.info() 输出调试信息,帮助分析程序运行状态。
  2. 记录错误信息:

    • 使用 logger.error()logger.exception() 捕捉并记录异常,方便排查问题。
    • 示例:
      try:1 / 0
      except ZeroDivisionError as e:logger.exception("捕获到异常:")
      
      输出:
      2023-11-06 12:00:00.004 | ERROR    | __main__:<module>:4 - 捕获到异常:
      Traceback (most recent call last):File "example.py", line 3, in <module>1 / 0
      ZeroDivisionError: division by zero
      
  3. 日志文件管理:

    • 将日志记录到文件,并设置日志文件大小限制或日志保留时间。
    • 示例:
      logger.add("runtime.log", rotation="1 MB", retention="7 days", compression="zip")
      logger.info("这是一个记录到文件的日志示例")
      

总结

from loguru import logger 的作用是引入 Loguru 库中的 logger 对象,用于记录程序的运行日志。通过 logger,我们可以轻松记录不同级别的信息,并将日志输出到控制台、文件或其他目标。

Loguru 因其简单的 API 和强大的功能,是替代标准库 logging 的优秀选择,特别适合需要快速实现日志功能的开发场景。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/65262.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

视频汇聚融合云平台Liveweb一站式解决视频资源管理痛点

随着5G技术的广泛应用&#xff0c;各领域都在通信技术加持下通过海量终端设备收集了大量视频、图像等物联网数据&#xff0c;并通过人工智能、大数据、视频监控等技术方式来让我们的世界更安全、更高效。然而&#xff0c;随着数字化建设和生产经营管理活动的长期开展&#xff0…

linux 查看服务是否开机自启动

一、centos6查看开机自启服务 chkconfig rpcbind --list chkconfig 服务 --list 二、centos7查看开机自启服务 1.systemctl list-unit-files 查看启动项 左边是服务名称&#xff0c;右边是状态&#xff0c;enabled是开机启动&#xff0c;disabled是开机不启动 systemctl l…

MySQL连接IDEA(Java Web)保姆级教程

第一步&#xff1a;新建项目(File)->Project 第二步&#xff1a;New Project(JDK最好设置1.8版本与数据库适配&#xff0c;详细适配网请到MySQL官网查询MySQL :: MySQL 8.3 Reference Manual :: Search Results) 第三步&#xff1a;点中MySQLTest(项目名)并连续双击shift键-…

Kibana安装教程——Linux

Kibana安装教程——Linux 一、安装 下载安装包&#xff1a; 官网下载地址&#xff1a;https://www.elastic.co/cn/downloads/kibana 上传包到linux 切换到安装目录下 解压&#xff1a;tar -zxvf kibana-7.17.1-linux-x86_64.tar.gz 重命名安装文件夹 mv kibana-7.17.1-linux-x…

FreeSql

官网 实体特性 Ado 它包括所有对 SQL 操作的封装&#xff0c;提供 ExecuteReader、ExecuteDataSet、ExecuteDataTable、ExecuteNonQuery、ExecuteScalar 等方法&#xff0c;使用起来和传统 SqlHelper 一样。 1、安装包 dotnet add package FreeSql dotnet add package FreeSq…

linux下搭建lamp环境(dvwa)

lamp简介 LAMP是指一组通常一起使用来运行动态网站或者服务器的自由软件名称首字母缩写&#xff1a; Linux&#xff0c;操作系统 Apache&#xff0c;网页服务器 MariaDB或MySQL&#xff0c;数据库管理系统或数据库服务器 PHP、Perl或Python&#xff0c;脚本语言 # ubuntu安装…

React第十八节 useEffect 用法使用技巧注意事项详解

1、概述 useEffect 是React中一个用于 将组件与外部系统同步的 Hook&#xff1b;在函数式组件中处理副作用函数的 Hook&#xff0c;用于替代类式组件中的生命周期函数&#xff1b; 可以在副作用函数中 实现以下操作&#xff1a; a、请求接口&#xff0c;获取后台提供数据 b、操…

Linux高并发服务器开发 第六天(rwx 对于目录和文件的区别 gcc编译器 动态库静态库)

目录 1.rwx 对于目录和文件的区别 2.gcc 编译器 2.1编译过程 2.2gcc 的其他参数 3.动态库和静态库 3.1函数库 1.rwx 对于目录和文件的区别 r 文件的内容可以被查看。支持cat、more、head...vim &#xff1b;目录的内容可以被查看。ls、tree …

腾讯云云开发 Copilot 深度探索与实战分享

个人主页&#xff1a;♡喜欢做梦 欢迎 &#x1f44d;点赞 ➕关注 ❤️收藏 &#x1f4ac;评论 目录 一、引言 二、产品介绍 三、产品体验过程 四、整体总结 五、给开发者的复用建议 六、对 AI 辅助开发的前景展望 一、引言 在当今数字化转型加速的时代&#xff0c;…

潮玩设备AI语音交互方案,ESP32-S3芯片模组物联网通信技术

在智能化的世界里&#xff0c;每一个设备都是一个节点&#xff0c;它们通过无线网络相互连接&#xff0c;形成一个庞大的智能网络。这些设备能够相互通信&#xff0c;理解并判断用户的需求&#xff0c;从而提供更加个性化的服务。 而这一切的背后&#xff0c;是强大的处理器和…

Jensen-Shannon Divergence:定义、性质与应用

一、定义 Jensen-Shannon Divergence&#xff08;JS散度&#xff09;是一种衡量两个概率分布之间差异的方法&#xff0c;它是Kullback-Leibler Divergence&#xff08;KL散度&#xff09;的一种对称形式。JS散度在信息论、机器学习和统计学等领域中具有广泛的应用。 给定两个概…

使用 Three.js 创建烟花粒子特效教程

使用 Three.js 创建烟花粒子特效教程 今天&#xff0c;我们将使用 Three.js 来实现一个简单而美观的烟花粒子效果。烟花会在屏幕随机位置生成&#xff0c;粒子在爆炸后呈现出散射、下降、逐渐消散的动态效果。先来看一下效果。 第一步&#xff1a;搭建基础场景 在正式实现烟花…

神经网络-VggNet

2014年VggNet被推出&#xff0c;获取了ILSVRC2014比赛分类项目的第二名&#xff0c;第一名是GoogleNet&#xff0c;该网络在下节介绍&#xff0c;本节主要介绍VggNet。 VggNet可以称为是一个家族&#xff0c;根据层数的不同包括了A、A-LRN、B、C、D等网络结构&#xff0c;其中…

docker-compose搭建sfpt服务器

1. 搭建 创建sftp目录&#xff0c;进入该目录创建docker-compose.yml文件内容如下&#xff1a; version: 3.7services:sftp:image: atmoz/sftpcontainer_name: sftpports:- "122:22"volumes:- ./sftp-data:/homeenvironment:SFTP_USERS: "liubei:liubei161:10…

计算机视觉目标检测-1

文章目录 摘要Abstract1.目标检测任务描述1.1 目标检测分类算法1.2 目标定位的简单实现思路1.2.1 回归位置 2.R-CNN2.1 目标检测-Overfeat模型2.1.1 滑动窗口 2.2 目标检测-RCNN模型2.2.1 非极大抑制&#xff08;NMS&#xff09; 2.3 目标检测评价指标 3.SPPNet3.1 spatial pyr…

减速机润滑油的选用原则

减速机在投入运行前必须加入适当粘度的润滑油&#xff0c;须使齿轮间摩擦减小&#xff0c;遇高负荷及冲击负荷时&#xff0c;减速机才能充分发挥其机能。那么&#xff0c;应该如何选择减速机的润滑油呢&#xff1f; 1、粘度选择&#xff1a;粘度是齿轮油的一个重要理化指标&…

解线性方程组

直接三角分解&#xff08;LU分解&#xff0c;Doolittle分解&#xff09; ATM分解&#xff08;追赶法&#xff0c;Crout分解&#xff0c;克劳特分解&#xff09; 平方根法&#xff08;Cholesky分解&#xff0c;乔列斯基分解&#xff09; 矩阵的范数

使用 OpenCV 在图像中添加文字

在图像处理任务中&#xff0c;我们经常需要将文本添加到图像中。OpenCV 提供了 cv2.putText() 函数&#xff0c;可以很方便地在图像上绘制文本&#xff0c;支持多种字体、颜色、大小和位置等参数。 本文将详细介绍如何使用 OpenCV 在图像中添加文字&#xff0c;介绍 cv2.putTe…

如何高效学习PHP框架源码

为什么学习php框架源码 学习PHP框架源码是软件开发领域中的一个重要环节&#xff0c;它带来了诸多益处&#xff0c;无论是对于个人技能的提升&#xff0c;还是对于实际项目开发的优化&#xff0c;都有着不可忽视的作用。以下是一些具体的原因&#xff0c;解释了为什么学习PHP框…

HAL库STM32硬件IIC驱动数字电位器MCP4017

目录 一、芯片特性 二、硬件电路 三、工程搭建 四、IIC硬件地址 五、驱动程序 项目需要&#xff0c;最近用到了一个IIC接口的数字电位器&#xff0c;型号&#xff1a;MCP4017T-502E。对应阻值5K&#xff0c;使用STM32G030F6的硬件IIC驱动&#xff0c;发现简单的不得了&…