XML解析
XML解析方式
- DOM解析
- SAX解析
DOM解析的工具
- Sun官方jaxp工具
- jdom工具
- dom4j工具
dom4j使用
查:
标签: element(“name”)
elements(“name”)
elements();
getName() 标签名称
getRootElement(): 根标签
属性: atrributeValue(“name”) 属性值
atrribute(“name”) 对象
atrributes() 属性对象列表
getName() : 属性名
getValue() 属性值
文本:
getText(); 当前标签的文本
elementText(“name”) 子标签的文本
增:
DocumentHelper.createDocument() 文档
addElement(“name”); 标签
addAtribute(”name”,”value” ) 属性
改:
setValue() 修改属性值
addAttribute(”同名“) 修改属性值
setText() 修改文本内容
删除:
detach() 标签、属性
getParent().remove(标签/属性)
XPath技术
1.1 作用
作用: 快速地查询到xml文件中节点。
当xml文件中的标签层次结构很深,那么如何来快速地定位到所需的标签呢?这就用到了xpath技术!!
1.2 体验xpath技术
1)导入jaxen-1.1-beta-6.jar dom4j的xpath插件包
2)在dom4j中使用xpath
List list = selectNodes(“xpath表达式”) 查询多个节点
Node node = selectSingleNode(“xpath表达式”) 查询一个节点
1.3 xpath表达式(重点)
/ 绝对路径 斜杠在最前面,代表xml文件的根。斜杠在中间,表示子元素。
// 相对路径 选择后代元素(不分层次结构)
* 通配 选择所有元素
[ ] 条件 选择什么条件下的元素。例如 /AAA/BBB[1] 选择第一个BBB子元素
@ 属性 选取属性
= 内容 (值)
and 逻辑与
text() 选取文本内容
SAX解析
2.1 引入
xml解析方法:
dom解析:原理xml解析引擎一次性把整个xml文件加载进内存,在内存创建一颗document树。
问题:大文件的话,使用dom解析效率比较低,甚至会导致内存溢出。
编码方式: 面向对象编程方式
sax解析: 原理加载一点,读取一点,处理一点。优势:占用的内存比较小。
编程方式:基于事件编程方式。
2.2 SAX解析工具
sun公司官方的sax解析工具。 在jdk中包含sax解析工具的api。org.xml.sax.*;
2.3 SAX解析的开发步骤
2.4 SAX案例
- | DOM解析 | SAX解析 |
---|---|---|
原理 | 一次性加载进内存,构造docuemnt数,内存占用比较大 | 加载一点,读取一点,内存占用相对小 |
读取顺序 | 可以读取XML文件任意位置信息,甚至往回读 | 只能是从上往下依次读取,不能往回读 |
操作方式 | 可以进行查询,也可以进行修改 | 只能查询 |
编码方式 | 面向对象编程方式,更加适合java开发者 | 基于事件编程方式,相对java开发难理解 |