为什么自定义 logging 过滤器无法打印指定等级日志信息?

心靈之曲
发布: 2024-11-14 16:30:35
原创
379人浏览过

为什么自定义 logging 过滤器无法打印指定等级日志信息?

自定义 logging 过滤器无法打印指定等级日志信息的问题

给定以下 python 代码:

class customfilter(logging.filter):
    def filter(self, record):
        message = record.getmessage()
        return 'custom' in message

customfilter = customfilter()

logger: logger = logging.getlogger()
logger.setlevel(logging.debug)
logger.addfilter(customfilter)

logger.debug('this is a debug message with custom keyword')
logger.info('this is an info message with custom keyword')
logger.warning('this is a warning message with custom keyword')
logger.error('this is an error message with custom keyword')
logger.critical('this is a critical message with custom keyword')
登录后复制

代码中使用了自定义日志过滤器 customfilter,意图只打印包含 'custom' 字符串的日志信息。然而,运行代码后,我们发现控制台只打印了警告、错误和严重错误级别的日志信息,而调试和信息级别的日志信息却不见踪影。

问题原因

问题不在于自定义过滤器本身,而在于代码的使用方式。在给定的代码中,我们没有为日志器添加处理程序(handler),因此日志信息没有地方输出。

知我AI
知我AI

一款多端AI知识助理,通过一键生成播客/视频/文档/网页文章摘要、思维导图,提高个人知识获取效率;自动存储知识,通过与知识库聊天,提高知识利用效率。

知我AI 101
查看详情 知我AI

正确的做法是先创建一个 handler,再将其添加到日志器中。常用的 handler 有 streamhandler,它将日志信息输出到控制台。

修改后的代码

import logging

# 创建一个流处理程序,将日志信息输出到控制台
handler = logging.StreamHandler()

# 创建一个自定义日志过滤器
class CustomFilter(logging.Filter):
    def filter(self, record):
        message = record.getMessage()
        return 'custom' in message

# 创建一个日志器,并为其设置级别、添加过滤器和处理程序
logger = logging.getLogger(__file__)
logger.setLevel(logging.DEBUG)
logger.addFilter(CustomFilter())
logger.addHandler(handler)

# 记录不同等级的日志信息
logger.debug('This is a debug message with custom keyword')
logger.info('This is an info message with custom keyword')
logger.warning('This is a warning message with custom keyword')
logger.error('This is an error message with custom keyword')
logger.critical('This is a critical message with custom keyword')
登录后复制

修改后的代码将正确地打印包含 'custom' 字符串的调试和信息级别的日志信息。

以上就是为什么自定义 logging 过滤器无法打印指定等级日志信息?的详细内容,更多请关注php中文网其它相关文章!

全能打印神器
全能打印神器

全能打印神器是一款非常好用的打印软件,可以在电脑、手机、平板电脑等设备上使用。支持无线打印和云打印,操作非常简单,使用起来也非常方便,有需要的小伙伴快来保存下载体验吧!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号