zoukankan      html  css  js  c++  java
  • python 的logging 的配置,有这一篇就够了

    参考 文章:https://www.cnblogs.com/nwpuxuezha/p/9038172.html

    python 自带

    
    import logging
    
    #输出的日志文件目录
    LOG_FILE_NAME = "logs/log.log"
    
    # 得到 logger 对象
    logger = logging.getLogger()
    
    
    # 初始化 logger
    def log_init():
        # 输出的格式
        formatter = logging.Formatter(
            fmt='%(asctime)s  %(filename)s  [line:%(lineno)d]  %(levelname)s :%(message)s',
            datefmt='%Y-%m-%d %H:%M:%S')
    
        #设置级别
        logger.setLevel(logging.DEBUG)
        
        #控制台的输出
        ch = logging.StreamHandler()
        ch.setFormatter(formatter)
    
        # log文件的记录
        fh = logging.FileHandler(LOG_FILE_NAME)
        fh.setFormatter(formatter)
    
        #将输出的流 添加给logger
        logger.addHandler(ch)
        logger.addHandler(fh)
    
    
    def test():
        logger.info("info")
        logger.error("error")
    
    if __name__ == "__main__":
        log_init()
        test()
    
    

    基于 YAML 的配置文件

    version: 1
    disable_existing_loggers: False
    formatters:
        simple:
            format: "%(asctime)s - %(filename)s - %(lineno)s - %(levelname)s - %(message)s"
    
    handlers:
        console:
            class: logging.StreamHandler
            level: INFO
            formatter: simple
            stream: ext://sys.stdout
    
        info_file_handler:
            class: logging.handlers.RotatingFileHandler
            level: INFO
            formatter: simple
            filename: logs/info.log
            maxBytes: 10485760 # 10MB
            backupCount: 20
            encoding: utf8
    
        error_file_handler:
            class: logging.handlers.RotatingFileHandler
            level: ERROR
            formatter: simple
            filename: logs/errors.log
            maxBytes: 10485760 # 10MB
            backupCount: 20
            encoding: utf8
    
        webdriver_handler:
            class: logging.handlers.RotatingFileHandler
            level: INFO
            formatter: simple
            filename: logs/webdriver.log
            maxBytes: 10485760 # 10MB
            backupCount: 20
            encoding: utf8
    
    loggers:
        webdriver_module:
            level: INFO
            handlers: [console]
            propagate: no
    
    root:
        level: INFO
        handlers: [console, info_file_handler, error_file_handler]
    
    
    
    
    import logging.config
    import os
    
    import yaml
    
    with open('logging.yaml') as f:
        if not os.path.exists('logs'):
            os.mkdir('logs')
        logging.config.dictConfig(yaml.safe_load(f.read()))
    
    
    def get_logging(name=None):
        if name:
            return logging.getLogger(name)
        return logging
    
    
    

    基于 JSON 的配置文件

  • 相关阅读:
    UDP与TCP报文格式,字段意义
    TCP报文头部解析
    SQL中IN和EXISTS用法的区别
    SQL中EXISTS的用法
    rabbitmq之一概念解释(信道、交换器和路由键、队列)
    Memcache,Redis,MongoDB三种非关系型数据库的对比
    linux chage
    linux用户组管理
    c++ decltype
    c++ 隐式转换(explicit与转换构造函数)
  • 原文地址:https://www.cnblogs.com/xibanqiu/p/13815062.html
Copyright © 2011-2022 走看看