你可以做一个简单的解析器表达式,比如*(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)
专业提示 1:有效性
如果您想确保没有不需要/意外的输入,请检查剩余数据:
-
解析后检查迭代器
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";
-
或者简单的 require qi::eoi 作为解析器表达式的一部分并检查返回值:
bool ok = qi::phrase_parse(line.cbegin(), line.cend(), *(qi::int_ >> qi::int_) >> qi::eoi, qi::space, v);
专业提示 2:“看妈妈,没有手”
由于语法是可以解析成这个数据结构的最简单的东西,你可以让 Spirit 做所有的猜测:
Live On Coliru
qi::phrase_parse(line.begin(), line.end(), qi::auto_, qi::space, v);
也就是说,一个只包含一个qi::auto_ 的语法。输出还是:
(20, 10)
(5, 3)