Ich habe noch nie XMLs verarbeitet, daher bin ich nicht sicher, wie CDATA in einer XML-Datei verarbeitet werden soll. Ich bin verloren in Knoten, Eltern, Kind Knoten, nList, etc.Verarbeitung von CDATA aus XML über DOM-Parser
Kann mir jemand sagen, was mein Problem ist aus diesen Codeschnipsel?
Meine getTagValue()
-Methode funktioniert für alle Tags außer "Details", die CDATA enthält.
.....
NodeList nList = doc.getElementsByTagName("Assignment");
for (int temp = 0; temp < nList.getLength(); temp++) {
Node nNode = nList.item(temp);
if (nNode.getNodeType() == Node.ELEMENT_NODE) {
Element eElement = (Element) nNode;
results = ("Class : " + getTagValue("ClassName", eElement)) +
("Period : " + getTagValue("Period", eElement)) +
("Assignment : " + getTagValue("Details", eElement));
myAssignments.add(results);
}
}
.....
private String getTagValue(String sTag, Element eElement) {
NodeList nlList = eElement.getElementsByTagName(sTag).item(0).getChildNodes();
Node nValue = (Node) nlList.item(0);
if((CharacterData)nValue instanceof CharacterData)
{
return ((CharacterData) nValue).getData();
}
return nValue.getNodeValue();
}
Abgesehen von Bogdan ausgezeichnete Erklärung, wenn Sie Xom verwenden können, Dom4J, etc, werden Sie wahrscheinlich besser für sie. –