bioinfoer

找回密码
立即注册
搜索
热搜: 活动 交友 discuz
发新帖

0

收听

12

听众

341

主题
发表于 2024-11-14 16:39:33 | 查看: 171| 回复: 0

1. logging模块简介

logging模块是Python内置的标准模块,主要用于输出运行日志,可以设置输出日志的等级、日志保存路径、日志文件回滚等;相比print,具备如下优点:

  1. 可以通过设置不同的日志等级,在release版本中只输出重要信息,而不必显示大量的调试信息;
  2. print将所有信息都输出到标准输出中,严重影响开发者从标准输出中查看其它数据;logging则可以由开发者决定将信息输出到什么地方,以及怎么输出;

Logger从来不直接实例化,经常通过logging模块级方法(Module-Level Function)logging.getLogger(name)来获得,其中如果name不给定就用root。名字是以点号分割的命名方式命名的(a.b.c)。对同一个名字的多个调用logging.getLogger()方法会返回同一个logger对象。这种命名方式里面,后面的loggers是前面logger的子logger,自动继承父loggers的log信息,正因为此,没有必要把一个应用的所有logger都配置一遍,只要把顶层的logger配置好了,然后子logger根据需要继承就行了。

logging.Logger对象扮演了三重角色:

  1. 首先,它暴露给应用几个方法以便应用可以在运行时写log.
  2. 其次,Logger对象按照log信息的严重程度或者根据filter对象来决定如何处理log信息(默认的过滤功能).
  3. 最后,logger还负责把log信息传送给相关的handlers.

2. logging模块使用

基本使用如下

配置logging基本的设置,然后在控制台输出日志。

import logging
logging.basicConfig(level = logging.INFO,format = '%(asctime)s - %(name)s - %(levelname)s - %(message)s')
logger = logging.getLogger(__name__)

logger.info("Start print log")
logger.debug("Do something")
logger.warning("Something maybe fail.")
logger.info("Finish")

运行后,控制台输出。

2014-11-14 16:35:53,073 - __main__ - INFO - Start print log
2014-11-14 16:35:53,073 - __main__ - WARNING - Something maybe fail.
2014-11-14 16:35:53,073 - __main__ - INFO - Finish

logging中可以选择很多消息级别,如:DEBUG < INFO < WARNING < ERROR < CRITICAL,通过赋予logger或者handler不同的级别,开发者就可以只输出错误信息到特定的记录文件,或者在调试时只记录调试信息。

将logger的级别改为 DEBUG ,再观察一下输出结果。

logging.basicConfig(level = logging.DEBUG,format = '%(asctime)s - %(name)s - %(levelname)s - %(message)s')

从输出结果可以看到,输出了debug的日志记录。

2014-11-14 16:36:36,041 - __main__ - INFO - Start print log
2014-11-14 16:36:36,042 - __main__ - DEBUG - Do something
2014-11-14 16:36:36,042 - __main__ - WARNING - Something maybe fail.
2014-11-14 16:36:36,042 - __main__ - INFO - Finish

收藏回复 显示全部楼层 道具 举报

您需要登录后才可以回帖 登录 | 立即注册

QQ|Archiver|手机版|小黑屋|bioinfoer ( 萌ICP备20244422号 )

GMT+8, 2025-1-29 06:58 , Processed in 0.080733 second(s), 30 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表