使用logging模块将屏幕打印的日志同时保存到本地,发现屏幕重复打印信息

最近在利用网上的代码来使用logging模块将屏幕打印的日志同时保存到本地,发现出现这样一个问题。
代码如下:

import logging
logger = logging.getLogger(__name__)
logger.setLevel(level = logging.INFO)
handler = logging.FileHandler("log.txt")
handler.setLevel(logging.INFO)
formatter = logging.Formatter('%(asctime)s - %(levelname)s - %(name)s -   %(message)s')
handler.setFormatter(formatter)
 
console = logging.StreamHandler()
console.setLevel(logging.INFO)
 
logger.addHandler(handler)
logger.addHandler(console)

得到以下部分结果
在这里插入图片描述
不难发现在控制台信息重复输出了,经过查找原因发现将logger = logging.getLogger(__name__)改为logger = logging.getLogger()即可。
推荐一个封装好的可以在控制台显示并保存到屏幕的函数代码。

import logging

def log():
    # 创建一个logger
    logger = logging.getLogger()
    # Log等级总开关,低于此级别的都不会记录
    logger.setLevel(logging.INFO)
    # 自定义log目录
    logfile = r'/media/a/data1/zrf/CD/CD_pipei/logs/log_train-hardnet-decoder-zhengti-test1.txt'
    # 创建一个handler,用于写入日志文件
    filehandler=logging.FileHandler(filename=logfile,encoding='utf-8')
    # 用于写到file的等级开关
    filehandler.setLevel(logging.INFO)
    # 再创建一个handler,用于输出到控制台
    consolehandler=logging.StreamHandler()
    # 输出到console的log等级的开关
    consolehandler.setLevel(logging.INFO)
    # 定义handler的输出格式
    formatter = logging.Formatter('%(asctime)s - %(thread)s - %(levelname)s - %(message)s')
    filehandler.setFormatter(formatter)
    consolehandler.setFormatter(formatter)
    # 将logger添加到handler里面
    logger.addHandler(filehandler)
    logger.addHandler(consolehandler)
    return logger

参考链接:python 日志模块-logging使用教程,将日志输出到控制台与文件中

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值