C++ 提升日志位置(索引)格式对齐

c++ boost log positional(indexed) format alignment

本文关键字:索引 格式 对齐 位置 日志 C++      更新时间:2023-10-16

>我尝试格式化提升日志输出,以便出于输出日志对齐原因,所选字段将始终具有特定宽度。

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
    );

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

    "[%1%] [%2%] [%3%]
  • [%|20t|%4%] %5%"
  • "[%1%] [%2%] [%3%]
  • [%-20s] %5%"
  • 琐碎::严重性 <<标准::设置(20)

我的许多尝试都抛出了以下错误:

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

目前,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
);