先写一个XML栗子:
<?xml version="1.0" encoding="UTF-8"?>
<books xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="{book.xsd}">
<book id="1001">
<name>从入门到放弃</name>
<auto>高人</auto>
<price>35.5</price>
</book>
<book id="1002">
<name>从删库到跑路</name>
<auto>高小人</auto>
<price>48.3</price>
</book>
<book id="1003">
<name>从java到光头</name>
<auto>高大人</auto>
<price>16.6</price>
</book>
</books>
这XML里books面有三个子book,book里面又有三个属性。且book有id。我们我们就用DOM来解析这个book.xml
DOM解析xml的步骤:
- 创建一个DocumentBuilderFactory的对象
- 创建一个DocumentBuilder对象
- 通过DocunmentBuilder的parse(...)方法得到Document对象
- 通过getElemntsByTagNAme(...)方法获得结点的列表
- 通过for循环遍历每一个结点
- 得到每个结点的属性和属性值
- 得到每个结点的结点值的节点名。
package com.bjsxt.DOM;
import java.io.IOException;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import org.w3c.dom.Document;
import org.w3c.dom.NamedNodeMap;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;
public class TestDOM {
public static void main(String[] args) throws ParserConfigurationException, SAXException, IOException {
// 1.创建一个DocumentBuilderFactory的对象
DocumentBuilderFactory dbf=DocumentBuilderFactory.newInstance();
// 2.创建一个DocumentBuilder对象
DocumentBuilder db=dbf.newDocumentBuilder();
// 3.通过DocunmentBuilder的parse(...)方法得到Document对象
Document doc = db.parse("book.xml");
// 4.通过getElemntsByTagNAme(...)方法获得结点的列表
NodeList nameList = doc.getElementsByTagName("book");
System.out.println(nameList.getLength());
// 5.通过for循环遍历每一个结点
for (int i = 0; i <nameList.getLength(); i++) {
//6.得到每个结点的属性和属性值
Node node = nameList.item(i);
//得到属性集合
NamedNodeMap attributes = node.getAttributes();
//循环遍历每一个属性
for (int j = 0; j <attributes.getLength(); j++) {
//得到每一个属性
Node id = attributes.item(j);
System.out.println("属性名称:"+id.getNodeName()+"\t属性的值:"+id.getNodeValue());
}
}
// 7.得到每个结点的结点值的节点名
System.out.println("\n得到内个结点的结点值和节点名");
for (int i = 0; i < nameList.getLength(); i++) {
System.out.println("\n子节点个数:"+nameList.getLength());
//得到每一个book结点
Node book = nameList.item(i);
NodeList childList = book.getChildNodes();
//遍历每一个结点
for (int j = 0; j <childList.getLength(); j++) {
Node childNode = childList.item(j);
//获取结点的类型
short type = childNode.getNodeType();
if (type==Node.ELEMENT_NODE) {
System.out.println("结点名称:"+childNode.getNodeName()+"----->"+childNode.getTextContent());
}
}
}
}
}
运行截图: