• python学习-----logging模块


    第一种方法:

    编程方法:

    1. import logging
    2. #记录器
    3. logger = logging.getLogger('applog')
    4. logger.setLevel('DEBUG')
    5. #必须设置为两个handler中级别更低的
    6. #处理器handler
    7. consoleHandler = logging.StreamHandler()
    8. consoleHandler.setLevel(logging.DEBUG)
    9. #没有给handler指定日志级别,将使用logger的级别
    10. fileHandler = logging.FileHandler(filename='addDemo.log')
    11. fileHandler.setLevel(logging.INFO)
    12. #
    13. # #formatter格式
    14. formatter = logging.Formatter('%(asctime)s - %(funcName)s - %(levelname)s - %(message)s')
    15. #里面的8,10实现了占位对齐
    16. #给处理器设置格式
    17. consoleHandler.setFormatter(formatter)
    18. fileHandler.setFormatter(formatter)
    19. #记录器要设置处理器
    20. logger.addHandler(consoleHandler)
    21. logger.addHandler(fileHandler)
    22. #定义一个过滤器
    23. flt = logging.Filter("cn.cccb")
    24. #关联过滤器
    25. # logger.addFilter(flt)
    26. fileHandler.addFilter(flt)
    27. #打印日志的代码
    28. logger.debug("this is debug log")
    29. logger.info("this is info log")
    30. logger.warning("this is warning log")
    31. logger.error("this is error log")
    32. logger.critical("this is critical log")

    第二种方法:

    配置文件方法:

    logging.conf

    1. [loggers]
    2. keys=root,applog
    3. [handlers]
    4. keys=fileHandler,consoleHandler
    5. [formatters]
    6. keys=simpleFormatter
    7. [logger_root]
    8. level=DEBUG
    9. handlers=consoleHandler
    10. [logger_applog]
    11. level=DEBUG
    12. handlers=fileHandler,consoleHandler
    13. qualname=applog
    14. propagate=0
    15. [handler_consoleHandler]
    16. class=StreamHandler
    17. args=(sys.stdout,)
    18. level=DEBUG
    19. formatter=simpleFormatter
    20. [handler_fileHandler]
    21. class=handlers.TimedRotatingFileHandler
    22. args=('applog.log','midnight',3600,0)
    23. level=DEBUG
    24. formatter=simpleFormatter
    25. [formatter_simpleFormatter]
    26. format=%(asctime)s|%(levelname)8s|%(filename)s[:%(lineno)d]|%(message)s
    27. datefmt=%Y-%m-%d %H:%M:%S

    main

    1. import logging.config
    2. logging.config.fileConfig("logging.conf")
    3. rootlogger = logging.getLogger()
    4. rootlogger.debug('debug')
    5. logger = logging.getLogger('applog')
    6. logger.debug('debug2')
    7. a = 'abc'
    8. try:
    9. int(a)
    10. except Exception as e:
    11. # logger.error(e)
    12. logger.exception(e)

    参考文件

    标准库系列:logging 日志打印 - 小康要好好学习 - 博客园

    Python基础之标准库logging 你还在用print来调试程序吗,OUT啦_哔哩哔哩_bilibili

  • 相关阅读:
    磕磕绊绊的双非硕秋招之路小结
    在Spring Boot项目中使用JPA
    第70讲:MySQL数据库全局锁的核心概念
    scrum|敏捷开发之任务看板
    Go语言中的defer关键字
    Yii缓存机制yii\caching\Cache
    移动端开发:WebView介绍和使用、JSBridge等
    android 获取局域网其他设备ip
    JVM中的STW(Stop The World)
    索引——MySQL
  • 原文地址:https://blog.csdn.net/qq_28057379/article/details/126783084