首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Rails日志中的缩进

Rails日志中的缩进
EN

Stack Overflow用户
提问于 2018-10-25 06:55:37
回答 1查看 261关注 0票数 7

在记录自定义信息时,例如在rake-task中,我想缩进日志行以获得更好的可读性。例如:

代码语言:javascript
复制
Seeding database...
  Importing xyz.csv...
    Skipping row 5 due to invalid value 'Unknown' in column 'year'
  Finished importing xyz.csv
Finished seeding database

在我的seeds.rb中,我使用以下方式进行日志记录:

代码语言:javascript
复制
logger = Logger.new(STDOUT)
logger.info('Seeding database...')

然而,Skipping row 5...的日志记录发生在一个服务中,这个服务不一定要从seeds.rb调用,而是可以从任何地方调用。因此,我无法硬编码正确的缩进(这听起来是个坏主意)。

一种可能是保留一个“缩进计数器”,当我开始导入一个文件时,它会增加,在完成时会减少。不过,我不确定如何从我的应用程序中的任何地方访问它,或者这是否是最好的解决方案。有什么想法吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-09-12 17:00:41

更好的解决方案是为服务对象提供一个记录器对象以及要处理的数据。这样,它就不必知道任何关于记录器首选项的信息。

并使用这样的方法:

代码语言:javascript
复制
require 'logger'

class IndentedLogger < Logger

  INDENTATION_STR = '  '.freeze
  attr_accessor :indentation

  def initialize(io, *args, **params)
    self.indentation = 0
    super
  end

  def indented
    return self.dup.tap{|l| l.indentation += 1 } unless block_given?
    self.indentation += 1
    yield self
    self.indentation -= 1
  end

  protected

  def format_message(severity, datetime, progname, msg)
    (@formatter || @default_formatter).call(severity, datetime, progname, "#{INDENTATION_STR*indentation}#{msg}")
  end

end

# Example:
logger = IndentedLogger.new(STDOUT)

logger.info "Foo"
logger.indented{
  logger.info "Foo"
  logger.indented.info "Indented even more"
}
logger.info "Foo"

以及服务呼叫- YourService.new(some_data, logger: logger.indented).process_or_whatever

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52983137

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档