博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
python中利用logging包进行日志记录时的logging.level设置选择
阅读量:5818 次
发布时间:2019-06-18

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

之前在用python自带的logging包进行日志输出的时候发现有些logging语句没有输出,感到比较奇怪就去查了一下logging文档。然后发现其在设置和引用时的logging level会影响最后的输出。logging包默认对输出分成了6个等级:

947235-20160913182535867-1367348947.png
这里的分值就代表了相应关键字出现的等级高低,NOTSET最低,CRITICAL最高。高等级的语句会覆盖低等级的语句。
一般我们用logging的时候会先在主程序配置一个logging类的格式,然后在子程序中直接引用即可()。如果我们在设置默认格式的时候设置的等级比之后调用是的要高,那么调用的logging语句将不会输出;反之,输出时默认等级也会被调用语句的等级覆盖。
下面用一个简单的程序说明下 (更具体例子可查阅):

import loggingimport sysdef test_log_level():    # set default logging configuration    logger = logging.getLogger()    # initialize logging class    logger.setLevel(logging.DEBUG)  # default log level    format = logging.Formatter("%(asctime)s - %(message)s")    # output format     sh = logging.StreamHandler(stream=sys.stdout)    # output to standard output    sh.setFormatter(format)    logger.addHandler(sh)        # use logging to generate log ouput     logger.info("this is info")    logger.debug("this is debug")    logger.warning("this is warning")    logging.error("this is error")    logger.critical("this is critical")test_log_level()

输出

2016-09-13 18:53:05,966 INFO - this is info2016-09-13 18:53:05,966 DEBUG - this is debug2016-09-13 18:53:05,966 WARNING - this is warning2016-09-13 18:53:05,967 ERROR - this is error2016-09-13 18:53:05,967 CRITICAL - this is critical

如果我们把logger的等级调高,比如到INFO

logger.setLevel(logging.INFO)

那么输出结果将是:

2016-09-13 18:52:37,492 INFO - this is info2016-09-13 18:52:37,492 WARNING - this is warning2016-09-13 18:52:37,492 ERROR - this is error2016-09-13 18:52:37,492 CRITICAL - this is critical

logging.debug的调用没有产生日志,也就是上面说的调用等级没有超过默认等级将不会有输出;而其他的调用等级超过默认等级的时候,日志记录的就是调用等级。

总结:因为一般日志系统中调用最多的就是logging.INFO,所以一般默认的等级设置不会太高选择DEBUG或INFO即可。通过调用logging的不同等级可以方便我们快速查阅标签从而找出bug。所以个人觉得这个logging模块还是需要好好看下文档理解掌握下的。

转载于:https://www.cnblogs.com/arkenstone/p/5869475.html

你可能感兴趣的文章
CentOS 6.5 下编译安装 Nginx 1.8.0
查看>>
tomcat安装完设定用户名和密码
查看>>
何必言精通——十年杂感(转载)
查看>>
HTML5 Video与Audio 视频与音频
查看>>
DataFrame
查看>>
Android UiAutomator UiDevice API
查看>>
Codeforces 372B Counting Rectangles is Fun
查看>>
函数式对象之私有字段和方法
查看>>
PSP总结报告
查看>>
[学习笔记]计算几何
查看>>
Windows下Apache整合Tomcat成功实例
查看>>
html5圆角
查看>>
spring整合ssmXML版
查看>>
导出excel身份证过长导致显示不正常自定义单元格格式解决方法
查看>>
VMX指令集
查看>>
Spark数据倾斜及解决方案
查看>>
IIS问题大全
查看>>
关于多项式的一些东西
查看>>
Oracle数据库中scott用户不存在的解决方法
查看>>
函数式编程语言
查看>>