- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试将 python MemoryHandler
添加到日志记录配置文件中。我正在使用与之前工作的文件处理程序类似的结构。我对收到的错误有点困惑,并且无法弄清楚我缺少什么才能将日志记录保存到内存中。下面包含了必要的信息。我们将不胜感激。
log_settings.conf
[loggers]
keys=root
[handlers]
keys=memHandler, consoleHandler
[formatters]
keys=fileFormatter, consoleFormatter
[logger_root]
level=DEBUG
handlers=memHandler, consoleHandler
[handler_consoleHandler]
class=StreamHandler
level=INFO
formatter=consoleFormatter
args=(sys.stdout,)
[handler_memHandler]
class=handlers.MemoryHandler
formatter=fileFormatter
args=(10, DEBUG, '%(logfilename)s')
[formatter_fileFormatter]
format=[%(asctime)s] [%(levelname)8s] --- (%(filename)15s:%(lineno)4s) %(message)s
datefmt=%Y-%m-%d %H:%M:%S
[formatter_consoleFormatter]
format=%(message)s
错误回溯
Traceback (most recent call last):
File "E:\BuildScript\proj_tcl\blr_sbz\blr_sbz_build.py", line 22, in <module>
main(args.jenkins, args.revision, args.jenkins_num)
File "E:\BuildScript\proj_tcl\blr_sbz\blr_sbz_build.py", line 10, in main
build(jenkins, revision, jenkins_num)
File "../scripts\build.py", line 17, in build
logging.info('Starting the FGPA build script')
File "C:\Program Files\Python36\lib\logging\__init__.py", line 1870, in info
root.info(msg, *args, **kwargs)
File "C:\Program Files\Python36\lib\logging\__init__.py", line 1301, in info
self._log(INFO, msg, args, **kwargs)
File "C:\Program Files\Python36\lib\logging\__init__.py", line 1437, in _log
self.handle(record)
File "C:\Program Files\Python36\lib\logging\__init__.py", line 1447, in handle
self.callHandlers(record)
File "C:\Program Files\Python36\lib\logging\__init__.py", line 1509, in callHandlers
hdlr.handle(record)
File "C:\Program Files\Python36\lib\logging\__init__.py", line 858, in handle
self.emit(record)
File "C:\Program Files\Python36\lib\logging\handlers.py", line 1213, in emit
self.flush()
File "C:\Program Files\Python36\lib\logging\handlers.py", line 1289, in flush
self.target.handle(record)
AttributeError: 'str' object has no attribute 'handle'
build.py
logging.config.fileConfig('../scripts/logging/log_settings.conf', defaults={'logfilename': '../scripts/logging/log.log'})
logging.info('Starting the FGPA build script')
最佳答案
改用此配置文件:
[loggers]
keys=root
[handlers]
keys=memHandler, consoleHandler
[formatters]
keys=fileFormatter, consoleFormatter
[logger_root]
level=DEBUG
handlers=memHandler
[handler_consoleHandler]
class=StreamHandler
level=INFO
formatter=consoleFormatter
args=(sys.stdout,)
[handler_memHandler]
class=handlers.MemoryHandler
formatter=fileFormatter
args=(10, DEBUG)
target=consoleHandler
[formatter_fileFormatter]
format=[%(asctime)s] [%(levelname)8s] --- (%(filename)15s:%(lineno)4s) %(message)s
datefmt=%Y-%m-%d %H:%M:%S
[formatter_consoleFormatter]
format=%(message)s
请注意,您不应将 consoleHandler
包含在根记录器的处理程序列表中。此外,您需要使用 target=
行设置目标,并且它需要引用目标处理程序的键。使用以下内容进行配置:
logging.config.fileConfig('logging.ini')
关于Python 记录到配置文件中初始化的 MemoryHandler,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44408130/
我正在尝试将 python MemoryHandler 添加到日志记录配置文件中。我正在使用与之前工作的文件处理程序类似的结构。我对收到的错误有点困惑,并且无法弄清楚我缺少什么才能将日志记录保存到内存
Python 的 logging模块有一个缓冲处理程序,MemoryHandler . 它需要一个capacity 参数。 容量的单位是什么? 最佳答案 缓冲区的容量是它可以容纳的条目数。每个条目代表
当记录到 MemoryHandler 时,当 numofentries > size 时,MemoryHandler 会删除旧条目。 我想避免这种行为,或者至少在日志中标记旧条目被抑制。 小测试用例:
我想在特定阈值后记录我的应用程序的消息。 10 条消息后说。我阅读了内存处理程序并使用了它。但是我发现它会立即记录消息,而不是像文档中所说的那样缓冲它们。这是代码 Handler h = new Fi
我找不到足够的文档来让它工作。我有非长时间运行的进程,这些进程在 stderr 上显示进度信息并使用 stdout 进行输出。我想要的是日志消息在进程退出时全部显示在最后,而且它也应该记录到一个文件中
我设置了日志记录模块 MemoryHandler 来排队 SMTPHandler 目标的调试和错误消息。我想要的是当包含所有调试语句的过程错误时发送一封电子邮件(每行一个)。相反,我得到的是每条调试消
我是一名优秀的程序员,十分优秀!