我尝试格式化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
);
我尝试过不同的格式,例如
我的许多尝试都引发了以下错误:
> Caught Exception in cyacollector main. Error: Unsupported format
> placeholder
答案 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
);