当前位置:   article > 正文

logger重复输出 python

logger重复

logger 重复输出 python

跑程序,需要控制多个变量,因此想着能够用几个循环来控制,然后每次跑得都能把中间输出放到对应的log文件里面,但是logger的输出在跑第二个程序时变成了每次重复两次,且对应的log文件也没有,而是在第一个程序的log文件里。

这里看了一下logger相关的代码,发现是logging.root.handlers还是第一个程序的,所以没有第二个程序的log文件,且在第二个程序运行时还会新添一个streamhandler,所以后面会有两个重复输出。同样,第三个程序,控制台有三个重复的输出。

!! 解决办法
在每个程序运行前,判断一下logging.root.handlers有没有,有的话就全部pop,然后新添!

def create_logger(cfg):
    root_path=get_root_path(cfg)
    log_dir = os.path.join(root_path, "logs")
    if not os.path.exists(log_dir): 
        os.makedirs(log_dir)
    time_str = time.strftime("%Y-%m-%d-%H-%M")
    log_name = "{}.log".format(time_str)
    log_file = os.path.join(log_dir, log_name)
    # set up logger
    print("=> creating log {}".format(log_file))
    head = "%(asctime)-15s %(message)s"
    ## =============  这里 亲测有效!! ==================
    while len(logging.root.handlers)>0:
        logging.root.handlers.pop()
    # ==================================================
    logging.basicConfig(filename=str(log_file), format=head)
    logger = logging.getLogger()
    logger.setLevel(logging.INFO) 
    console = logging.StreamHandler()
    logging.getLogger("").addHandler(console)

    logger.info("---------------------Cfg is set as follow--------------------")
    logger.info(cfg)
    logger.info("-------------------------------------------------------------")
    return logger, log_file
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop】
推荐阅读
相关标签
  

闽ICP备14008679号