python中logging会重复写日志的问题分析-创新互联

现象

我们提供的服务有:网站建设、成都网站设计、微信公众号开发、网站优化、网站认证、长海ssl等。为1000+企事业单位解决了网站和推广的问题。提供周到的售前咨询和贴心的售后服务,是有科学管理、有技术的长海网站制作公司

小强python全栈自动化测试班的学员问到,会出现重复写日志的情况,如下

python中logging会重复写日志的问题分析

原因



当第二次调用log的时候,根据getLogger(name)里的name获取同一个logger,而这个logger里已经有了第一次你添加的handler,第二次调用又添加了一个handler,也就是说这个logger里有了两个同样的handler,所以就会出现调用几次就会有几个handler

解决方案


在日志记录完之后removeHandler

例如:logger.removeHandler(streamhandler)

除此之外你也可以去判定下,如果logger.handlers列表为空,则添加,否则,直接去写日志,例如

if not logger.handlers:
    xxxx
logger.error('百度搜索:小强测试品牌')

另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


分享文章:python中logging会重复写日志的问题分析-创新互联
分享地址:http://pwwzsj.com/article/disioi.html