python logging 重复写日志问题解决办法详解

作者:huilan_same 时间:2021-04-29 13:19:30 

python logging 重复写日志问题

用Python的logging模块记录日志时,遇到了重复记录日志的问题,第一条记录写一次,第二条记录写两次,第三条记录写三次。。。很头疼,这样记日志可不行。网上搜索到了原因与解决方案:

原因:没有移除handler
解决:在日志记录完之后removeHandler

修改前示例代码:


import logging

def log(message):
logger = logging.getLogger('testlog')

streamhandler = logging.StreamHandler()
streamhandler.setLevel(logging.ERROR)
formatter = logging.Formatter('%(asctime)s - %(levelname)s - %(name)s - %(message)s')
streamhandler.setFormatter(formatter)

logger.addHandler(streamhandler)
logger.error(message)

if __name__ == '__main__':
log('hi')
log('hi too')
log('hi three')

修改前输出结果:

2016-07-08 09:17:29,740 - ERROR - testlog - hi
2016-07-08 09:17:29,740 - ERROR - testlog - hi too
2016-07-08 09:17:29,740 - ERROR - testlog - hi too
2016-07-08 09:17:29,740 - ERROR - testlog - hi three
2016-07-08 09:17:29,740 - ERROR - testlog - hi three
2016-07-08 09:17:29,740 - ERROR - testlog - hi three

修改后示例代码:


import logging

def log(message):
logger = logging.getLogger('testlog')

streamhandler = logging.StreamHandler()
streamhandler.setLevel(logging.ERROR)
formatter = logging.Formatter('%(asctime)s - %(levelname)s - %(name)s - %(message)s')
streamhandler.setFormatter(formatter)

logger.addHandler(streamhandler)
logger.error(message)

# 添加下面一句,在记录日志之后移除句柄
logger.removeHandler(streamhandler)

if __name__ == '__main__':
log('hi')
log('hi too')
log('hi three')

修改后输出结果:

2016-07-08 09:32:28,206 - ERROR - testlog - hi
2016-07-08 09:32:28,206 - ERROR - testlog - hi too
2016-07-08 09:32:28,206 - ERROR - testlog - hi three

深度解析:

Google之后,大概搞明白了,就是你第二次调用log的时候,根据getLogger(name)里的name获取同一个logger,而这个logger里已经有了第一次你添加的handler,第二次调用又添加了一个handler,所以,这个logger里有了两个同样的handler,以此类推,调用几次就会有几个handler。。

所以这里有以下几个解决办法:

  1. 每次创建不同name的logger,每次都是新logger,不会有添加多个handler的问题。(ps:这个办法太笨,不过我之前就是这么干的。。)

  2. 像上面一样每次记录完日志之后,调用removeHandler()把这个logger里的handler移除掉。在log方法里做判断,如果这个logger已有handler,则不再添加handler。

  3. 与方法2一样,不过把用pop把logger的handler列表中的handler移除。

下面是方法3与方法4的代码示例:

方法3:


import logging

def log(message):
logger = logging.getLogger('testlog')

# 这里进行判断,如果logger.handlers列表为空,则添加,否则,直接去写日志
if not logger.handlers:
streamhandler = logging.StreamHandler()
streamhandler.setLevel(logging.ERROR)
formatter = logging.Formatter('%(asctime)s - %(levelname)s - %(name)s - %(message)s')
streamhandler.setFormatter(formatter)
logger.addHandler(streamhandler)

logger.error(message)

if __name__ == '__main__':
log('hi')
log('hi too')
log('hi three')

方法4:


import logging

def log(message):
logger = logging.getLogger('testlog')

streamhandler = logging.StreamHandler()
streamhandler.setLevel(logging.ERROR)
formatter = logging.Formatter('%(asctime)s - %(levelname)s - %(name)s - %(message)s')
streamhandler.setFormatter(formatter)

logger.addHandler(streamhandler)

logger.error(message)

# 用pop方法把logger.handlers列表中的handler移除,注意如果你add了多个handler,这里需多次pop,或者可以直接为handlers列表赋空值
logger.handlers.pop()
# logger.handler = []

if __name__ == '__main__':
log('hi')
log('hi too')
log('hi three')

这几种方法都亲试可行,个人觉得方法3判断更加优雅,你觉得呢?

来源:https://blog.csdn.net/huilan_same/article/details/51858817

标签:python,logging,重复,日志
0
投稿

猜你喜欢

  • python 类对象的析构释放代码演示

    2023-11-22 18:54:53
  • 什么是XML?

    2007-10-29 12:53:00
  • 快速掌握怎样选择准备安装的 MySQL版本

    2008-12-17 16:42:00
  • 详解Python中的装饰器、闭包和functools的教程

    2023-12-30 13:43:03
  • Python 使用Numpy对矩阵进行转置的方法

    2022-07-10 09:53:19
  • golang中切片copy复制和等号复制的区别介绍

    2024-02-13 15:10:13
  • Python实现的下载8000首儿歌的代码分享

    2021-02-03 05:41:51
  • 淘宝网提供的国内NPM镜像简介和使用方法

    2024-04-17 10:10:16
  • JavaScript数组合并的8种常见方法小结

    2024-04-16 09:32:55
  • 解析MySQL数据库性能优化的六大技巧

    2024-01-13 02:18:49
  • 一个效果写的HashTable代码

    2024-04-10 13:57:49
  • 一文秒懂python中的 \\r 与 end=‘’ 巧妙用法

    2022-10-06 08:33:28
  • jupyter 中文乱码设置编码格式 避免控制台输出的解决

    2023-04-27 08:01:13
  • python高级特性和高阶函数及使用详解

    2022-09-17 20:13:50
  • MySQL数据库搜索中的大小写敏感性

    2008-11-24 12:44:00
  • Python Pygame制作雪夜烟花景

    2023-10-21 08:57:07
  • 微信小程序如何修改本地缓存key中单个数据的详解

    2024-05-09 10:34:57
  • js+css实现select的美化效果

    2024-04-16 09:52:25
  • golang gorm实现get请求查询案例测试

    2024-05-09 10:09:31
  • 对pandas replace函数的使用方法小结

    2022-07-04 15:20:24
  • asp之家 网络编程 m.aspxhome.com