- DOM解析操作
- 在应用程序中,基于DOM的XML分析器将一个XML文档转换成一个对象模型的集合(DOM树),通过对这个对象模型的操作来实现对XML文档数据的操作
- 通过DOM接口,应用程序可以在任何时候访问XML文档中的任何一部分数据,这种利用DOM接口的机制也被称作为随机访问机制
- 利弊:DOM树所提供的随机访问方式给应用程序开发带来了很大的灵活性,然而,在文档比较大或结构比较复杂时,对内存的需求就比较高,而且对结构复杂的树遍历也很耗时
- 四大核心接口:Node、Document、Element、Attr;NodeList:一个节点的集合;NamedNodeMap:一组节点和其唯一名称对应的一一对应的关系,主要用于属性节点的表示
读取操作
- 建立一个DocumentBuilderFactory(便于管理,单例模式)
- 建立DocumentBuilder(构造者模式,例如一家人去公园买票,由儿童票、老年票、成人票组成)
- 建立Document,(文件路径问题可参考:https://www.cnblogs.com/HangZhe/p/6015936.html)
- 建立NodeList
- 进行XML信息读取
/*
import java.io.IOException;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import org.junit.Test;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;
*/
public void testRead() {
//建立DocumentBuilderFactory,取得DocumentBuilder
DocumentBuilderFactory factory=DocumentBuilderFactory.newInstance();
DocumentBuilder builder=null;
try {
builder=factory.newDocumentBuilder();
} catch (ParserConfigurationException e) {
e.printStackTrace();
}
//定义Document接口对象,通过DocumentBuilder类进行DOM树的转换操作
Document doc=null;
try {
doc=builder.parse(this.getClass().getClassLoader().getResource("xml.xml").getPath());//找到在src路径下文件
} catch (SAXException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
//查找节点
NodeList naList=doc.getElementsByTagName("book");//拿到book下的节点集合
for (int i = 0; i < naList.getLength(); i++) {//遍历book节点集合
Element e=(Element) naList.item(i);//其中一个book节点
System.out.println(e.getElementsByTagName("name").item(0).getFirstChild().getNodeValue());//book节点下的name标签的值
NodeList aList=e.getElementsByTagName("author");//拿到book节点下的author下的节点集合
for (int j = 0; j < aList.getLength(); j++) {
Element nb=(Element) aList.item(j);//拿到其他一个author节点
System.out.println(nb.getElementsByTagName("name").item(0).getFirstChild().getNodeValue());//拿到author节点下的name标签的值
System.out.println(nb.getElementsByTagName("birthyear").item(0).getFirstChild().getNodeValue());//拿到author节点下的birthyear标签的值
}
}
}
XML文件写入
- 建立一个DocumentBuilderFactory(便于管理,单例模式)
- 建立DocumentBuilder(构造者模式,例如一家人去公园买票,由儿童票、老年票、成人票组成)
- 建立Document
- 建立各个操作节点
- 设置节点文本内容
- 设置个节点关系
- 输出到文档中
public void testWrite() {
//建立DocumentBuilderFactory,取得DocumentBuilder
DocumentBuilderFactory factory=DocumentBuilderFactory.newInstance();
DocumentBuilder builder=null;
try {
builder=factory.newDocumentBuilder();
} catch (ParserConfigurationException e) {
e.printStackTrace();
}
//定义Document接口对象,通过DocumentBuilder类进行DOM树的转换操作
Document doc=null;
doc=builder.newDocument();
//建立各个操作节点
Element books=doc.createElement("books");
Element book=doc.createElement("book");
Element name=doc.createElement("name");
Element author=doc.createElement("author");
Element aname=doc.createElement("name");
Element abirth=doc.createElement("birthyear");
//设置节点内容
name.appendChild(doc.createTextNode("从入门到住院2"));
aname.appendChild(doc.createTextNode("佚名2"));
abirth.appendChild(doc.createTextNode("1996"));
//设置节点关系
author.appendChild(aname);
author.appendChild(abirth);
book.appendChild(name);
book.appendChild(author);
books.appendChild(book);
doc.appendChild(books);
//输出到文档中
TransformerFactory tf=TransformerFactory.newInstance();
Transformer t=null;
try {
t=tf.newTransformer();
} catch (TransformerConfigurationException e) {
e.printStackTrace();
}
t.setOutputProperty(OutputKeys.ENCODING, "utf-8");//设置编码
DOMSource source=new DOMSource(doc);//doc
StreamResult result=new StreamResult(new File("XXX.xml"));//xml文件
//输出
try {
t.transform(source, result);
} catch (TransformerException e) {
e.printStackTrace();
}
}