博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Python logger模块
阅读量:4641 次
发布时间:2019-06-09

本文共 1746 字,大约阅读时间需要 5 分钟。

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对象扮演了三重角色:
       首先,它暴露给应用几个方法以便应用可以在运行时写log.
       其次,Logger对象按照log信息的严重程度或者根据filter对象来决定如何处理log信息(默认的过滤功能).
       最后,logger还负责把log信息传送给相关的handlers.
 

2 logging模块使用

2.1 基本使用

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

import logginglogging.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")

运行时,控制台输出,

1 2016-10-09 19:11:19,434 - __main__ - INFO - Start print log2 2016-10-09 19:11:19,434 - __main__ - WARNING - Something maybe fail.3 2016-10-09 19:11:19,434 - __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的日志记录

2016-10-09 19:12:08,289 - __main__ - INFO - Start print log2016-10-09 19:12:08,289 - __main__ - DEBUG - Do something2016-10-09 19:12:08,289 - __main__ - WARNING - Something maybe fail.2016-10-09 19:12:08,289 - __main__ - INFO - Finish

 

转载于:https://www.cnblogs.com/yahengwang/p/11314695.html

你可能感兴趣的文章
iOS - 事件处理全过程(补充)
查看>>
js基本概述
查看>>
5天学会fx-5800计算器测量编程(二) fx-5800函数学习
查看>>
Android 开发之 ---- bootloader (LK)
查看>>
android获取周围AP信息(下)
查看>>
linux 网络设备驱动
查看>>
使用 JDBC 驱动程序
查看>>
transform 属相拉伸变形
查看>>
用USBasp下载程序
查看>>
【数据库】oracle基本操作
查看>>
16.2.2 Space Needed for keys
查看>>
Codeforces Round #270(利用prim算法)
查看>>
选择排序
查看>>
怎样设计接口?
查看>>
Rabbitmq 加入用户訪控制台(guest无法登陆控制台问题)
查看>>
数据挖掘十大经典算法
查看>>
MDI窗体
查看>>
两个有序数组中找中位数或者第K大的元素
查看>>
使用 SP_OAXXX 创建文件夹,注意区别于 xp_cmdshell --mkdir xxx
查看>>
2. Probability
查看>>