python控制台打印log输出重复的解决方法

作者:橙好测试开发 时间:2021-02-23 04:05:17 

在我们使用log模块输出日志时,经常会遇到log输出重复的问题,如下:

先来看这个文件log.py的代码:


代码示例:

'''
功能描述:实现控制台和文件同时记录日志的功能
编写人:超哥
编写日期:
步骤分析:
  1-配置日志记录器名称
  2-配置日志级别
  3-配置日志格式(可以分别设置,也可以统一设置)
  4-创建并添加handler-控制台
  5-创建并添加handler-文件
  6-提供对外获取logger
'''

import logging
import sys

def log():
   # 1 - 配置日志记录器名称
   logger = logging.getLogger('AutoTest')

   # 2-配置日志级别
   logger.setLevel(logging.DEBUG)

   # 3-配置日志格式(可以分别设置,也可以统一设置)
   format = logging.Formatter('%(name)s-%(asctime)s-%(message)s')

   # 4 - 创建并添加handler - 控制台
   sh = logging.StreamHandler()
   sh.setFormatter(format)
   logger.addHandler(sh)

   # 5 - 创建并添加handler - 文件
   fh = logging.FileHandler('test.log')
   fh.setFormatter(format)
   logger.addHandler(fh)

   # 6 - 提供对外获取logger
   return logger

if __name__ == '__main__':
   logger = log()
   logger.info('使用函数定义的log方法')

我们在同一目录下创建另外一个文件:

在我们导入写好的log.py文件


from xx目录 import log

 log().info('xxx1')

 log().info('xxx2')

 log().info('xxx3')

输出:

python控制台打印log输出重复的解决方法

这个结果什么鬼?明明三句话,打印出来这么多,这其实是log在使用的常遇到的坑,通过debug你会发现,每次调用都会创建句柄,所以重复,如图:

第一句调用之后,handlers里面已经存在了两个handler,分别是控制台句柄StreamHandler和文件句柄FileHandler,下面图中是第二句调用添加句柄

python控制台打印log输出重复的解决方法

执行后会发现handlers里面多了一个StreamHandler

python控制台打印log输出重复的解决方法

怎么解决这种情况,有两个方案,咱们分别列出两种方案代码:

第一种,第一使用单例模式,在log.py文件中增加一行:logger = log() ,这句的作用就是提前实例化好对象,其他模块使用都适用该对象,所以别的模块导入语句要改成:from xxx包.log import logger ,然后使用logger.info('xxxx') 输出日志即可

   ……省略上方代码


     # 6 - 提供对外获取logg的方法
     return logger
 #增加一行
 logger = log()

 if __name__ == '__main__':
     logger = log()
     logger.info('使用函数定义的log方法')

导入:


from xx包 import logger

 logger.info('xxx1')

 logger.info('xxx2')

 logger.info('xxx3')

输出:

python控制台打印log输出重复的解决方法

第二个方案:log.py每次判断handlers是否已存在


 ……
     # 4 - 创建并添加handler - 控制台
     sh = logging.StreamHandler()
     sh.setFormatter(format)

     # 5 - 创建并添加handler - 文件
     fh = logging.FileHandler('test.log')
     fh.setFormatter(format)

     #在新增handler时判断是否为空
     if not logger.handlers:
         logger.addHandler(sh)
         logger.addHandler(fh)

     # 6 - 提供对外获取logg的方法
     return logger

 if __name__ == '__main__':
     logger = log()
     logger.info('使用函数定义的log方法')

导入文件代码保持不变:


from xx包 import log

 log().info('xxx1')

 log().info('xxx2')

 log().info('xxx3')

输出:

python控制台打印log输出重复的解决方法

针对面向对象的方案同样是以上两个,请自行解决

来源:https://blog.csdn.net/rainshine1190/article/details/116675853

标签:python,控制台,log
0
投稿

猜你喜欢

  • 配置高可用性的MySQL服务器负载均衡群集

    2009-01-04 12:43:00
  • Mysql数据库实现多字段过滤的方法

    2024-01-16 11:35:48
  • SQL Server导入导出数据方法

    2007-08-17 09:50:00
  • Python中的re正则表达式模块

    2022-09-13 15:07:40
  • Python的Tornado框架实现图片上传及图片大小修改功能

    2023-10-27 06:23:43
  • 教你在SQL Server数据库中导入导出数据

    2008-12-09 14:42:00
  • Python 静态方法和类方法实例分析

    2021-07-08 19:25:37
  • python给视频添加背景音乐并改变音量的具体方法

    2021-01-26 20:18:47
  • 详解 Python 读写XML文件的实例

    2022-05-03 23:36:15
  • Python离线安装openpyxl模块的步骤

    2021-08-10 16:04:04
  • 通过Django Admin+HttpRunner1.5.6实现简易接口测试平台

    2023-05-24 19:07:45
  • Python Multiprocessing多进程 使用tqdm显示进度条的实现

    2021-04-03 19:15:08
  • 如何动态添加Form项?

    2009-11-18 20:44:00
  • Python线程之定位与销毁的实现

    2023-09-25 11:47:19
  • MySQL内外连接的具体使用

    2024-01-17 13:52:49
  • php传值和传引用的区别点总结

    2024-03-18 11:26:39
  • vue实现给div绑定keyup的enter事件

    2024-05-13 09:08:51
  • pytorch打印网络结构的实例

    2023-11-04 15:15:51
  • Python使用pyautocad+openpyxl处理cad文件示例

    2022-05-24 11:44:18
  • 原生js实现五子棋游戏

    2024-06-18 03:22:13
  • asp之家 网络编程 m.aspxhome.com