• python logging 重复打印问题


    我的问题:

    1. 在项目中由于在做个py文件中定义了handlers,导致在项目中定义几次就会重复几次

    正确的处理办法

    1. 只在一个文件中定义内容,然后在其他的py文件中引用即可
    import os
    import logging
    from logging.handlers import TimedRotatingFileHandler
    
    BASE_DIR = os.path.dirname(os.path.abspath(__file__))
    # log file
    
    LOG_FILE = os.path.join(BASE_DIR, 'data/info.log')
    
    logger = logging.getLogger("Rotating Log")
    logger.setLevel(logging.INFO)
    
    handler = TimedRotatingFileHandler(LOG_FILE,
                                       when="D",
                                       interval=1,
                                       backupCount=5)
    logger.addHandler(handler)
    logging = logger
    

    更新:

    LOG_FILE = os.path.join(BASE_DIR, 'data/info.log')
    
    logger = logging.getLogger("Rotating Log")
    logger.setLevel(logging.INFO)
    formatter = logging.Formatter('%(asctime)s - %(filename)s[line:%(lineno)d] - %(levelname)s: %(message)s')
    
    handler = TimedRotatingFileHandler(LOG_FILE,
                                       when="S",
                                       interval=1,
                                       backupCount=5)
    handler.setFormatter(formatter)
    logger.addHandler(handler)
    
    
    # file_handler = logging.FileHandler(LOG_FILE)
    # file_handler.setLevel(level=logging.INFO)
    # file_handler.setFormatter(formatter)
    
    # 可以打印到控制台
    # stream_handler = logging.StreamHandler()
    # stream_handler.setLevel(logging.DEBUG)
    # stream_handler.setFormatter(formatter)
    
    # logger.addHandler(file_handler)
    # logger.addHandler(stream_handler)
    
    logging = logger
    
    
    
  • 相关阅读:
    小黄衫获奖感言
    原型设计
    20210326编程作业
    阅读任务
    准备工作
    cmd命令行批量修改文件名后缀
    【智能算法】模拟退火算法
    【智能算法】粒子群寻优算法
    【并行计算】基于OpenMP的并行编程
    Python科学计算——前期准备
  • 原文地址:https://www.cnblogs.com/qianxunman/p/14273569.html
Copyright © 2020-2023  润新知