zoukankan      html  css  js  c++  java
  • python中利用logging包进行日志记录时的logging.level设置选择

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

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

    import logging
    import sys
    
    def 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 info
    2016-09-13 18:53:05,966 DEBUG - this is debug
    2016-09-13 18:53:05,966 WARNING - this is warning
    2016-09-13 18:53:05,967 ERROR - this is error
    2016-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 info
    2016-09-13 18:52:37,492 WARNING - this is warning
    2016-09-13 18:52:37,492 ERROR - this is error
    2016-09-13 18:52:37,492 CRITICAL - this is critical
    

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

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

  • 相关阅读:
    [置顶] RGB颜色查询对照表
    3.3FactoryMethod——工厂方法
    从零开始学C++之数据封装与抽象:分别用C和C++来实现一个链栈
    C# 自定义事件
    Qt4--加密日记本(子例化QMainWindow文本加密解密)
    SharePoint PerformancePoint Service-PowerShell
    Windows下安装Eric5时出现的“Sorry, please install QtHelp.”问题解决办法
    Char* ,CString ,WCHAR*之间的转换
    [C++基础]关键词volatile
    备忘--简单比较SPSS、RapidMiner、KNIME以及Kettle四款数据分析工具
  • 原文地址:https://www.cnblogs.com/arkenstone/p/5869475.html
Copyright © 2011-2022 走看看