Я пытаюсь написать парсер для файла csv, используя библиотеку boost.spirit. Я обнаружил следующую ошибку компиляции. Я новичок в boost.spirit, может кто-нибудь определить причины?
Сообщение об ошибке:
Ошибка C2664: 'bool boost :: spirit :: qi :: rule :: parse (Iterator &, const Iterator &, Context &, const Skipper &, Attribute &) const': невозможно преобразовать аргумент 1 из 'const char *' в 'std :: _ String_iterator >> &'
И мой код:
#pragma once
#define BOOST_SPIRIT_USE_PHOENIX_V3
#include<vector>
#include<string>
#include<memory>
#include<boost/iostreams/device/mapped_file.hpp> // for mmap
#include<boost/utility/string_ref.hpp>
#include<boost/spirit/include/qi.hpp>
#include<boost/spirit/include/qi_grammar.hpp>
#include<boost/spirit/include/qi_real.hpp>
#include<boost/spirit/include/phoenix.hpp>
#include<boost/spirit/include/qi_symbols.hpp>
typedef boost::string_ref CsvField;
typedef std::vector<CsvField> CsvLine;
typedef std::vector<CsvLine> CsvFile;
namespace qi = boost::spirit::qi;
template <typename T> struct CsvParser : qi::grammar<T, CsvFile()> {
CsvParser() : CsvParser::base_type(lines) {
using namespace qi;
using boost::phoenix::construct;
using boost::phoenix::size;
using boost::phoenix::begin;
using boost::spirit::qi::float_;
field = raw[*~char_(",\r\n")][_val = construct<CsvField>(begin(qi::_1), size(qi::_1))]; // semantic action
//field = qi::float_;
line = field % ',';
lines = line % eol;
}
// declare: line, field, fields
qi::rule<T, CsvFile()> lines;
qi::rule<T, CsvLine()> line;
qi::rule<T, CsvField()> field;
};
Код действительно заимствован из Простейший способ прочитать CSV-файл, сопоставленный с памятью?, поэтому я понятия не имею. Я использую Microsoft Visual Studio 2015 и буст 1.16.0.
Эта же ошибка возникает, если я заменяю typedef boost::string_ref CsvField
на typedef std::string
или заменяю синтаксический анализатор поля на field = *(~char_(",\r\n"))
.
Кроме того, файл, который я анализирую, на самом деле является стандартным файлом CSV, поэтому любые предложения об альтернативных методах анализа приветствуются. Единственная загвоздка в том, что в файле миллионы строк, поэтому стандартный построчный синтаксический анализ у меня не работает.