Я пытаюсь выяснить, как QXmlStreamReader работает для приложения C ++, которое я пишу.Файл XML, который я хочу проанализировать, представляет собой большой словарь с запутанной структурой и множеством символов Unicode, поэтому я решил попробовать небольшой тестовый пример с более простым документом.К сожалению, я врезался в стену.Вот пример XML-файла:
<?xml version="1.0" encoding="UTF-8" ?>
<persons>
<person>
<firstname>John</firstname>
<surname>Doe</surname>
<email>john.doe@example.com</email>
<website>http://en.wikipedia.org/wiki/John_Doe</website>
</person>
<person>
<firstname>Jane</firstname>
<surname>Doe</surname>
<email>jane.doe@example.com</email>
<website>http://en.wikipedia.org/wiki/John_Doe</website>
</person>
<person>
<firstname>Matti</firstname>
<surname>Meikäläinen</surname>
<email>matti.meikalainen@example.com</email>
<website>http://fi.wikipedia.org/wiki/Matti_Meikäläinen</website>
</person>
</persons>
... и я пытаюсь разобрать его с помощью этого кода:
int main(int argc, char *argv[])
{
if (argc != 2) return 1;
QString filename(argv[1]);
QTextStream cout(stdout);
cout << "Starting... filename: " << filename << endl;
QFile file(filename);
bool open = file.open(QIODevice::ReadOnly | QIODevice::Text);
if (!open)
{
cout << "Couldn't open file" << endl;
return 1;
}
else
{
cout << "File opened OK" << endl;
}
QXmlStreamReader xml(&file);
cout << "Encoding: " << xml.documentEncoding().toString() << endl;
while (!xml.atEnd() && !xml.hasError())
{
xml.readNext();
if (xml.isStartElement())
{
cout << "element name: '" << xml.name().toString() << "'"
<< ", text: '" << xml.text().toString() << "'" << endl;
}
else if (xml.hasError())
{
cout << "XML error: " << xml.errorString() << endl;
}
else if (xml.atEnd())
{
cout << "Reached end, done" << endl;
}
}
return 0;
}
... затем я получаю этот вывод:
C: \ xmltest \ Debug> xmltest.exe example.xml
Запуск ... имя файла: example.xml
Файл открыт ОК
Кодировка:
Ошибка XML: Обнаруженонеправильно закодированный контент.
Что случилось?Этот файл не может быть проще и выглядит для меня непротиворечивым.С моим исходным файлом я также получаю пустую запись для кодировки, отображаются имена записей (), но, увы, текст () также пуст.Любые предложения очень ценятся, лично я глубоко озадачен.