//导入的包
import java.io.FileNotFoundException;
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.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;
//写实现
public static void main(String[] args) {
// 1、得到DOM解析器的工厂实例
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
try {
// 2、从DOM工厂获得DOM解析器
DocumentBuilder db = dbf.newDocumentBuilder();
// 3、解析XML文档,得到一个Document,即DOM树
Document doc = db.parse("dogs.xml");
// 4、得到所有student节点列表信息
NodeList petList = doc.getElementsByTagName("dog");
// 5、循环读取xml文件中的宠物信息
System.out.println("XML文件中宠物的初始化信息:");
for (int i = 0; i < petList.getLength(); i++) {
<span style="white-space:pre"> </span>Node pet = petList.item(i);//获取节点
<span style="white-space:pre"> </span>for (Node node = pet.getFirstChild(); node != null; node = node.getNextSibling()) { //再从该节点进行循环其子节点
<span style="white-space:pre"> </span>if (node.getNodeType() == Node.ELEMENT_NODE) {
<span style="white-space:pre"> </span>String name = node.getNodeName(); //获取节点名称
<span style="white-space:pre"> </span>String value = node.getFirstChild().getNodeValue(); //获取节点内容
<span style="white-space:pre"> </span>System.out.print(name + ":" + value + "\t");
<span style="white-space:pre"> </span>}
<span style="white-space:pre"> </span>}
<span style="white-space:pre"> </span>System.out.println();
}
} catch (ParserConfigurationException e) {
<span style="white-space:pre"> </span>e.printStackTrace();
} catch (FileNotFoundException e) {
<span style="white-space:pre"> </span>e.printStackTrace();
} catch (SAXException e) {
<span style="white-space:pre"> </span>e.printStackTrace();
} catch (IOException e) {
<span style="white-space:pre"> </span>e.printStackTrace();
}
}