要实现不在悬停信息中显示marker.message和marker.code,可以使用以下代码示例:
import logging
class NoMessageCodeFilter(logging.Filter):
def filter(self, record):
# 如果悬停信息中存在marker.message或marker.code,则返回False,表示不输出该日志消息
if hasattr(record, 'marker') and ('message' in record.marker or 'code' in record.marker):
return False
return True
# 创建日志记录器
logger = logging.getLogger(__name__)
# 创建日志处理器
handler = logging.StreamHandler()
# 创建日志格式化器
formatter = logging.Formatter('%(levelname)s - %(message)s')
# 设置日志处理器的格式化器
handler.setFormatter(formatter)
# 创建日志过滤器
filter = NoMessageCodeFilter()
# 设置日志处理器的过滤器
handler.addFilter(filter)
# 将处理器添加到日志记录器
logger.addHandler(handler)
# 输出日志消息
logger.debug('Debug message')
logger.info('Informational message')
logger.warning('Warning message', extra={'marker': {'message': 'Marker message'}})
logger.error('Error message', extra={'marker': {'code': 123}})
在上述代码中,我们创建了一个名为NoMessageCodeFilter的自定义日志过滤器。该过滤器会检查日志记录中的marker属性,如果其中包含'message'或'code',则返回False,表示不输出该日志消息。
然后,我们创建了一个日志记录器logger,并为其添加了一个StreamHandler处理器。接着,我们创建了一个日志格式化器formatter,并将其设置为处理器的格式化器。然后,我们创建了一个NoMessageCodeFilter过滤器,并将其添加到处理器中。最后,我们通过logger.debug、logger.info、logger.warning和logger.error输出了一些日志消息,其中部分消息包含了'message'或'code'属性,但由于设置了过滤器,这些消息不会被输出。
运行上述代码,只会输出以下日志消息:
DEBUG - Debug message
INFO - Informational message
上一篇:不再显示GAC信息的结果
下一篇:不在选择查询中