dom会将xml文档加载进内存,形成dom树(document对象),将文档的各个组成部分封装为对象。
优点:可以对dom树进行增删改查。
缺点:dom树非常占内存,解析速度慢。
逐行读取,基于事件驱动
优点:不占内存,速度快
缺点:只能读取,不能回写
JAXP:sun公司提供的解析器,支持dom和sax,不过使用的不多。
JDOM: DOM4J的前身
DOM4J:全称是dom for java,是jdom的升级版,性能优异,使用较为广泛。
下载dom4j相关的jar包,解压后拷贝到web项目的lib文件夹下
<?xml version="1.0" encoding="UTF-8"?>
<students>
<student id="1001">
<name>alex</name>
<age>20</age>
</student>
<student>
<name>jan</name>
<age>22</age>
<![CDATA[
if(5>3&&3<6)<abc></abc>
]]>
</student>
<student>
<name>john</name>
<age>12</age>
</student>
<student>
<name>marry</name>
<age>20</age>
</student>
</students>
读取xml文件:
package firsttomcats;
import java.util.List;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;
import org.junit.Test;
public class dom4j {
@Test
public void test1() throws DocumentException {
//创建一个xml解析对象
SAXReader read=new SAXReader();
//把xml文档加载到document对象中
Document doc=read.read("src/1.xml");
//获取根节点
Element root=doc.getRootElement();
//获取当前节点的所有子节点
List list=root.elements();
Element third=(Element)list.get(2);
String name=third.element("name").getText();
System.out.println(name);
}
@Test
public void test2() throws DocumentException {
//创建一个xml解析对象
SAXReader reader=new SAXReader();
//把xml文档加载到document对象中
Document doct=reader.read("src/1.xml");
//获取根节点
Element root=doct.getRootElement();
select(root);
}
//递归
private void select(Element ele) {
//输出当前节点的名字
System.out.println(ele.getName());
for(int i=0;i<ele.nodeCount();i++) {
//取出下标为i的节点
Node node=ele.node(i);
//判断当前节点是否为标签
if(node instanceof Element) {
select((Element) node);
}else {
System.out.println(node.getText());
}
}
}
}
原文:https://www.cnblogs.com/hzdwwzz/p/10361975.html