【发布时间】:2014-09-12 10:10:14
【问题描述】:
如何使用 DOM 解析器解析以下 xml - name 节点重复到 n 级
<Services>
<service name ="qwerty" id="">
<File rootProfile="abcd" extension="acd">
<Columns>
<name id="0" profileName="DATE" type="java"></name>
<name id="1" profileName="DATE" type="java"></name>
.
.
.
<Columns>
</File>
<File rootProfile="efg" extension="ghi">
<Columns>
<name id="a" profileName="DATE" type="java"></name>
<name id="b" profileName="DATE" type="java"></name>
.
.
.
<Columns>
</File>
</service>
</Services>
我使用以下代码获取值:
public static void xmlEditor() throws SAXException, IOException {
try {
File xmlFile = new File("config/ServiceConfig.xml");
DocumentBuilderFactory documentFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder documentBuilder = null;
documentBuilder = documentFactory.newDocumentBuilder();
org.w3c.dom.Document doc = documentBuilder.parse(xmlFile);
doc.getDocumentElement().normalize();
NodeList nodeList0 = doc.getElementsByTagName("Service");
NodeList nodeList1 = doc.getElementsByTagName("File");
NodeList nodeList2 = doc.getElementsByTagName("name");
System.out.println("Root element :" + doc.getDocumentElement().getNodeName());
for (int temp0 = 0; temp0 < nodeList0.getLength(); temp0++) {
Node node0 = nodeList0.item(temp0);
System.out.println("\nElement type :" + node0.getNodeName());
Element Service = (Element) node0;
if (node0.getNodeType() == Node.ELEMENT_NODE) {
System.out.println("-----------------" + temp0 + "----------------------------------");
System.out.println("name : " + Service.getAttribute("name"));
System.out.println("id : " + Service.getAttribute("id"));
for (int temp = 0; temp < nodeList1.getLength(); temp++) {
Node node1 = nodeList1.item(temp);
System.out.println("\nElement type :" + node1.getNodeName());
Element File = (Element) node1;
if (node1.getNodeType() == Node.ELEMENT_NODE) {
System.out.println("rootProfile:" + File.getAttribute("rootProfile"));
System.out.println("extension : " + File.getAttribute("extension"));
for (int temp1 = 0; temp1 < nodeList2.getLength(); temp1++) {
Node node2 = nodeList2.item(temp1);
System.out.println("\nElement type :" + node2.getNodeName());
Element name = (Element) node2;
if (node2.getNodeType() == Node.ELEMENT_NODE) {
System.out.println("id:" + name.getAttribute("id"));
System.out.println("profileName : " + name.getAttribute("profileName"));
System.out.println("type : " + name.getAttribute("type"));
}
}
}
}
}
}
}
}
并且正在获取第一级节点 File 本身正在获取 name 的所有值,包括下一个文件节点有助于避免这种情况
我得到的输出是
name:-----
id :-----
rootProfile:--------
extension:-----------
id:o
profileName:
type:
id:1
profileName:
type:
id:a
profileName:
type:
id:b
profileName:
rootProfile:--------
extension:-----------
id:o
profileName:
type:
id:1
profileName:
type:
id:a
profileName:
type:
id:b
profileName:
【问题讨论】: