- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
[loggers]
keys=root
[handlers]
keys=consoleHandler,errorHandler,debugHandler
[formatters]
keys=errorFormatter,debugFormatter
[logger_root]
level=DEBUG
handlers=consoleHandler,errorHandler,debugHandler
propagate=0
[handler_consoleHandler]
class=StreamHandler
level=DEBUG
formatter=debugFormatter
args=(sys.stdout,)
[handler_errorHandler]
class=FileHandler
level=ERROR
formatter=errorFormatter
args=('errors.log',)
[handler_debugHandler]
class=FileHandler
level=DEBUG
formatter=debugFormatter
args=('debugs.log',)
[formatter_errorFormatter]
style={
format=
{asctime} - {name} - {levelname} - line {lineno} - {message}
datefmt=%d/%m/%y - %H:%M:%S
[formatter_debugFormatter]
style={
format={asctime} - {name} - {levelname} - {message}
datefmt=%d/%m/%y - %H:%M:%S
如果我有一个像上面那样的配置文件,我如何访问 debugHandler
以便我可以像 debugHandler.addFilter(my_custom_filter)
那样做?
我实际上是在尝试将 DEBUG
消息发送到 debugs.log
并将 ERROR
消息发送到 errors.log
,但目前 ERROR
消息也被发送到我不想要的 debugs.log
。现在,基于 this StackOverflow post ,这是可以通过过滤器实现的,但为了添加过滤器,我需要一个 logging.Handler
对象,但我不知道如何获取它。
提前致谢:~)
最佳答案
是的,您需要在 debug_handler 上添加过滤器,但是您不能通过 fileConfig 添加过滤器.
来自文档:
The fileConfig() API is older than the dictConfig() API and does not provide functionality to cover certain aspects of logging. For example, you cannot configure Filter objects, which provide for filtering of messages beyond simple integer levels, using fileConfig(). If you need to have instances of Filter in your logging configuration, you will need to use dictConfig(). Note that future enhancements to configuration functionality will be added to dictConfig(), so it’s worth considering transitioning to this newer API when it’s convenient to do so.
所以考虑使用 dictConfig (没有任何理由让您不切换到 dictConfig
,无论您的配置如何,因为它更好、更新、更灵活,并且将添加所有 future 的好东西).
所以你的配置,转换为 dictConfig
看起来像这样(可以按原样粘贴和测试):
import logging
from logging import config
class FileFilter:
"""Allow only LogRecords whose severity levels are below ERROR."""
def __call__(self, log):
if log.levelno < logging.ERROR:
return 1
else:
return 0
logging_config = {
'version': 1,
'formatters': {
'error_formatter': {
'format': '{asctime} - {name} - {levelname} - line {lineno} - {message}',
'style': '{',
'datefmt': '%d/%m/%y - %H:%M:%S',
},
'debug_formatter': {
'format': '{asctime} - {name} - {levelname} - {message}',
'style': '{',
'datefmt': '%d/%m/%y - %H:%M:%S',
},
},
'filters': {
'file_filter': {
'()': FileFilter,
},
},
'handlers': {
'console_handler': {
'class': 'logging.StreamHandler',
'formatter': 'debug_formatter',
},
'error_handler': {
'class': 'logging.FileHandler',
'formatter': 'debug_formatter',
'level': 'ERROR',
'filename': 'errors.log',
},
'debug_handler': {
'class': 'logging.FileHandler',
'formatter': 'debug_formatter',
'filters': ['file_filter'],
'filename': 'debug.log',
},
},
'root': {
'level': 'DEBUG',
'handlers': ['console_handler', 'error_handler', 'debug_handler'],
},
}
config.dictConfig(logging_config)
logger = logging.getLogger(__name__)
# these get logged to the console and only to the debugs.log file
# if you want just the debug messages logged to the file, adjust the filter
logger.debug('this is a debug message')
logger.info('this is an info message')
logger.warning('this is a warning message')
# this get logged to the console and only to the errors.log file
logger.error('this is an error message')
logger.critical('this is a critical message')
输出:
27/09/19 - 07:52:44 - __main__ - DEBUG - this is a debug message # also to debug.log
27/09/19 - 07:52:44 - __main__ - INFO - this is an info message # also to debug.log
27/09/19 - 07:52:44 - __main__ - WARNING - this is a warning message # also to debug.log
27/09/19 - 07:52:44 - __main__ - ERROR - this is an error message # also to errors.log but not to debug.log
27/09/19 - 07:52:44 - __main__ - CRITICAL - this is a critical message # also to errors.log but not to debug.log
如果您出于某种神秘原因(我看不到任何原因)坚持使用较旧的 API,fileConfig
,请参阅 this answer它使用自定义格式化程序,实现相同的目的,但没有过滤器。
关于python - 如何只记录某个级别名称的python日志记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58123869/
我正在尝试做这样的事情:Name[i] = "Name"+ (i+1) 在 forloop 中,这样数组的值将是:Name[0] = Name1,Name[1] = Name2,Name[2] = N
我读了here,在GSP中我们可以这样写: ${params.action} 从GSP中,我们可以使用${params.action}作为参数调用Javascript函数(请参阅here)。 是否有其
我的问题:非常具体。我正在尝试想出解析以下文本的最简单方法: ^^domain=domain_value^^version=version_value^^account_type=account_ty
我创建了一条与此类似的路线: Router::connect("/backend/:controller/:action/*"); 现在我想将符合此模式的每个 Controller 路由重命名为类似
我在 Visual Studio 2013 项目中收到以下警告: SQL71502 - Procedure has an unresolved reference to object 最佳答案 这可以
任何人都可以指导我使用名称/值 .NET 集合或 .NET 名称/值字典以获得最佳性能吗?请问最好的方法是什么?我的应用程序是 ASP.NET、WCF/WF Web 应用程序。每个集合应该有 10 到
我在 Zend Framework 2 中有一个默认模块: namespace Application\Controller; use Zend\Mvc\Controller\AbstractActi
这是表格: 关于javascript - 在 javascript 中,这是一个有效的结构吗? : document. 名称.名称.值?,我们在Stack Overflow上找到一个类似的
HtmlHelper.ActionLink(htmlhelper,string linktext,string action) 如何找出正确的路线? 如果我有这个=> HtmlHelper.Actio
我需要一些有关如何将 Controller 定义传递给嵌套在 outer 指令中的 inner 指令的帮助。请参阅http://plnkr.co/edit/Om2vKdvEty9euGXJ5qan一个
请提出一个数据结构来表示内存中的记录列表。每条记录由以下部分组成: 用户名 积分 排名(基于积分)- 可选字段- 可以存储在记录中或可以动态计算 数据结构应该支持高效实现以下操作: Insert(re
错误 : 联合只能在具有兼容列类型的表上执行。 结构(层:字符串,skyward_number:字符串,skyward_points:字符串)<> 结构(skyward_number:字符串,层:字符
我想要一个包含可变数量函数的函数,但我希望在实际使用它们之前不要对它们求值。我可以使用 () => type 语法,但我更愿意使用 => type 语法,因为它似乎是为延迟评估而定制的。 当我尝试这样
我正在编写一个 elisp 函数,它将给定键永久绑定(bind)到当前主要模式的键盘映射中的给定命令。例如, (define-key python-mode-map [C-f1] 'pytho
卡在R中的错误上。 Error in names(x) <- value : 'names' attribute must be the same length as the ve
我有字符串,其中包含名称,有时在字符串中包含用户名,后跟日期时间戳: GN1RLWFH0546-2020-04-10-18-09-52-563945.txt JOHN-DOE-2020-04-10-1
有人知道为什么我会收到此错误吗?这显示将我的项目升级到新版本的Unity3d之后。 Error CS0103: The name `Array' does not exist in the curre
由于 Embarcadero 的 NNTP 服务器从昨天开始就停止响应,我想我可以在这里问:我使用非数据库感知网格,我需要循环遍历数据集以提取列数、它们的名称、数量行数以及每行中每个字段的值。 我知道
在构建Android应用程序的子项目中,我试图根据根build.gradle中的变量设置版本代码/名称。 子项目build.gradle: apply plugin: 'com.android.app
示例用例: 我有一个带有属性“myProperty”的对象,具有 getter 和 setter(自 EcmaScript 5 起支持“Property Getters 和 Setters”:http
我是一名优秀的程序员,十分优秀!