c ++ boost log position(索引)格式对齐

时间:2017-01-25 14:59:30

标签: c++ boost boost-log

我尝试格式化boost日志输出,以便选择的字段始终具有特定宽度,以便输出日志对齐。

add_file_log(
        keywords::file_name = s.str(),
        keywords::rotation_size = log_info.log_file_size,
        keywords::max_size = log_info.log_file_amount * log_info.log_file_size,
        keywords::target = log_info.log_path,
        keywords::open_mode = std::ios::out | std::ios::app,
        keywords::auto_flush = true,
        keywords::format =
        expressions::format("[%1%] [%2%] [%3%] [%4%] %5%")
        % expressions::format_date_time< boost::posix_time::ptime >("TimeStamp", "%Y-%m-%d %H:%M:%S.%f")
        % expressions::attr<unsigned int>("ThreadID")
        % expressions::attr<string>("Scope")
        % trivial::severity
        % expressions::smessage
    );

我尝试过不同的格式,例如

  • &#34; [%1%] [%2%] [%3%] [%| 20t |%4%]%5%&#34;
  • &#34; [%1%] [%2%] [%3%] [%-20s]%5%&#34;
  • trivial :: severity&lt;&lt;的std ::运输及工务局局长(20)

我的许多尝试都引发了以下错误:

> Caught Exception in cyacollector main. Error: Unsupported format
> placeholder

1 个答案:

答案 0 :(得分:1)

目前,Boost.Log中的expressions::format仅支持%N%形式的位置占位符。此格式不允许其他参数,例如宽度或精度。大多数情况下,这是因为此格式化程序已将格式化的字符串插入格式模板中,因此此时无法应用大多数参数。

但是,您可以通过修改format的参数来实现您想要的效果。您可以使用max_size_decor装饰器和std::setw操纵器的组合来实现日志输出中每个列的固定宽度的效果。

add_file_log(
    ...,
    keywords::format =
    expressions::format("[%1%] [%2%] [%3%] [%4%] %5%")
        % expressions::max_size_decor< char >(30)[ expressions::stream << std::setw(30) << expressions::format_date_time< boost::posix_time::ptime >("TimeStamp", "%Y-%m-%d %H:%M:%S.%f") ]
        % expressions::max_size_decor< char >(10)[ expressions::stream << std::setw(10) << expressions::attr<unsigned int>("ThreadID") ]
        % expressions::max_size_decor< char >(20)[ expressions::stream << std::setw(20) << expressions::attr<string>("Scope") ]
        % expressions::max_size_decor< char >(5)[ expressions::stream << std::setw(5) << trivial::severity ]
        % expressions::smessage
);