Java XML:ClassCastException DeferredTextImpl

Rob*_* IV 8 java xml parsing nodelist

这是我的代码:

// get the factory
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();

try {

    // Using factory get an instance of document builder
DocumentBuilder db = dbf.newDocumentBuilder();

// parse using builder to get DOM representation of the XML file
    dom = db.parse(file);

} catch (ParserConfigurationException pce) {
    pce.printStackTrace();
} catch (SAXException se) {
    se.printStackTrace();
} catch (IOException ioe) {
    ioe.printStackTrace();
}

NodeList n1 = dom.getChildNodes();
Element e1 = (Element) n1.item(0);

System.out.println(n1.getLength());
System.out.println(e1.getNodeName());

NodeList n2 = n1.item(0).getChildNodes();
Element e2 = (Element) n2.item(0);   //Line 61

System.out.println(n2.getLength());
System.out.println(e2.getNodeName());
Run Code Online (Sandbox Code Playgroud)

这是我的XML文件:

<?xml version="1.0" encoding="utf-8"?>

<test-fw:test
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:test-fw="http://simitar/test-fw"> 

<rule-tree>
<rule class="matchlines">
<property name="contiguous"> true</property>
<property name="inOrder">false</property>
<property name="exact">false</property>
<property name="lines">modelInstantiated</property>
</rule>
<rule class="matchlines">
<property name="contiguous"> true</property>
<property name="inOrder">true</property>
<property name="exact">false</property>
<property name="lines">InitEvent</property>
</rule>
</rule-tree>

</test-fw:test>
Run Code Online (Sandbox Code Playgroud)

这是我的输出:

1
test-fw:test
Exception in thread "main" java.lang.ClassCastException: com.sun.org.apache.xerces.internal.dom.DeferredTextImpl cannot be cast to org.w3c.dom.Element
    at testpack.Main.run(Main.java:61)
    at testpack.Main.main(Main.java:86)
Run Code Online (Sandbox Code Playgroud)

我一直收到这个错误.我完全迷失了.我不知道该怎么做.我希望能够拥有一个节点,并能够抓住它的所有子节点并将它们放入数组或列表中,这样我就可以遍历它们.

这是我的所有进口:

import java.io.File;
import java.io.IOException;
import java.util.List;
import java.util.Stack;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;

import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;
Run Code Online (Sandbox Code Playgroud)

我一直在努力让这个Java解析这个XML文件.

Ano*_*sse 14

NodeList n1 = dom.getChildNodes();
Element e1 = (Element) n1.item(0);
Run Code Online (Sandbox Code Playgroud)

节点不是Element,而是a Node.

试试这个:

Node no1 = (Node) n1.item(0);
Run Code Online (Sandbox Code Playgroud)

例如,节点可以是文本节点或元素.特别是,

<root>
<element/>
</root>
Run Code Online (Sandbox Code Playgroud)

4个节点.甲root 元件,一个文本节点包含\n,所述element 元件另一和文本节点含有\n.