В настоящее время я изо всех сил пытаюсь разобрать XML-документы, потому что QDomElement, похоже, не может определить правильный nodeType.
Мой XML-документ имеет следующее содержимое:
<?xml version="1.0" encoding="UTF-8"?>
<note>
<to>Tove</to>
<from>
<me>Jani</me>
</from>
<heading>Reminder</heading>
<body>Don't forget me this weekend!</body>
</note>
Код для чтения в документе следующий:
QFile xmlFile("note.xml");
if (!xmlFile.open(QIODevice::ReadOnly)) {
qDebug() << "error while opening file";
}
QDomDocument xmlDoc;
if (!xmlDoc.setContent(&xmlFile)) {
qDebug() << "error while setting xml content";
}
QDomElement rootElement = xmlDoc.documentElement();
QDomElement firstLevel = rootElement.firstChildElement();
while (!firstLevel.isNull()) {
qDebug() << firstLevel.tagName() << firstLevel.text() << firstLevel.nodeType();
firstLevel = firstLevel.nextSiblingElement();
}
xmlFile.close();
Моя проблема в том, что даже если он содержит только текстовые элементы, я всегда получаю QDomNode :: ElementNode при вызове firstLevel.nodeType()
. Но для синтаксического анализа важно знать правильный nodeType. Что мне нужно сделать, чтобы получить настоящий тип?
С уважением, Frogtime