码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • unittest自动测试多个用例时,logging模块重复打印解决


    网上好多说是用这个方法,但没有解决:

    logger.propagate = False

    成功解决方法, 如果当前日志器里handler已存在就不重复添加,为空再添加,避免日志重复输出:

    1. import logging,os,sys
    2. class Log_info(object):
    3. def __init__(self,fileName):
    4. path = os.path.dirname(os.path.dirname(__file__))
    5. try:
    6. self.logs_path = path + r'/'+ fileName + '/'
    7. except:
    8. print("未找到指定文件夹:%s,请核实!" % fileName)
    9. os._exit(0)
    10. # 指定日志文件名,获取当前执行的py文件名,将日志存放到指定test_logs文件夹中
    11. self.filename = self.logs_path + str(os.path.basename(sys.argv[0]).split(".")[0]) + '.log'
    12. # 指定输出的格式和内容
    13. self.format = '%(asctime)s [%(filename)s]-<%(funcName)s> %(levelname)s:%(message)s'
    14. # 指定时间格式
    15. self.datefmt = '%Y-%m-%d %H:%M:%S'
    16. self.logger = logging.getLogger(__name__)
    17. def main(self):
    18. self.logger.setLevel(logging.INFO)
    19. format = logging.Formatter(self.format,datefmt=self.datefmt)
    20. # 如果当前日志器里handler已存在就不重复添加,为空再添加,避免日志重复输出
    21. if not self.logger.handlers:
    22. # 日志输出到文件
    23. file_handler = logging.FileHandler(self.filename)
    24. file_handler.setLevel(logging.INFO)
    25. file_handler.setFormatter(format)
    26. # 使用StreamHandler输出到屏幕
    27. console = logging.StreamHandler()
    28. console.setLevel(logging.INFO)
    29. console.setFormatter(format)
    30. # 添加两个Handler
    31. self.logger.addHandler(file_handler)
    32. self.logger.addHandler(console)
    33. return self.logger.info

  • 相关阅读:
    mysql—面试50题—1
    layer.load方法不加载,Ajax为同步时,layer.load方法不加载
    第三部分:领域驱动设计之分析模式和设计模式应用于模型
    SpringBoot - @InitBinder注解详解
    TIS-prescan
    聚美优品API 根据ID取商品详情 Onebound跨境电商api接口
    点击化学PEG试剂DBCO-PEG4-NHS,1427004-19-0知识特点总结
    为了这个语言,微软支持其创建者成立了一个团队
    【毕业设计】基于Arduino的智能灌溉系统 - 嵌入式 单片机 物联网
    Chapter 32 MySQL入门
  • 原文地址:https://blog.csdn.net/z564359805/article/details/125424101
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号