字符串内容如下:
20 10 5 3...
它是一对int的列表。如何使用精神将其解析为std::vector<std::pair<int, int>>
?
std::string line;
std::vector<std::pair<int, int>> v;
boost::spirit::qi::phrase_parse(
line.cbegin(),
line.cend(),
(
???
),
boost::spirit::qi::space
);
答案 0 :(得分:3)
您可以执行简单的解析器表达式,例如*(int_ >> int_)
(请参阅教程和these文档pages)。
<强> Live On Coliru 强>
#include <boost/spirit/include/qi.hpp>
#include <boost/fusion/include/std_pair.hpp>
namespace qi = boost::spirit::qi;
int main() {
std::string line = "20 10 5 3";
std::vector<std::pair<int, int>> v;
qi::phrase_parse(line.cbegin(), line.cend(), *(qi::int_ >> qi::int_), qi::space, v);
for (auto& p : v) {
std::cout << "(" << p.first << ", " << p.second << ")\n";
}
}
打印
(20, 10)
(5, 3)
如果您想确保没有不需要/意外的输入,请检查剩余数据:
解析后检查迭代器
auto f = line.cbegin(), l = line.cend();
qi::phrase_parse(f, l, *(qi::int_ >> qi::int_), qi::space, v);
if (f!=l)
std::cout << "Unparsed input '" << std::string(f,l) << "'\n";
或简单需要qi::eoi
作为解析器表达式的一部分并检查返回值:
bool ok = qi::phrase_parse(line.cbegin(), line.cend(), *(qi::int_ >> qi::int_) >> qi::eoi, qi::space, v);
由于语法很简单,可以解析为这个数据结构,你可以让Spirit做所有的猜测:
<强> Live On Coliru 强>
qi::phrase_parse(line.begin(), line.end(), qi::auto_, qi::space, v);
那是一个只由一个qi::auto_
组成的语法。输出仍然是:
(20, 10)
(5, 3)