1.引入
问题:当时用dom4j查询比较深的层次结构的节点时,比较麻烦
2.作用
快速获取节点对象
3.语法
/ 绝对路径 表示从xml的根位置开始或子元素(一个层次结构)
// 相对路径 表示不分任何层次结构的选择元素。
* 通配符 表示匹配所有元素
[] 条件 表示选择什么条件下的元素
@ 属性 表示选择属性节点
and 关系 表示条件的与关系(等价于&&
text() 文本 表示选择文本内容
4.使用
a.导入XPath支持jar包
b.代码:
//先写一个Student.XML文件
<students></students>
//比如寻找id="s002"的student标签
String path = "//student[@id=‘s002‘]";
//寻找name为王五的人标签
String path = "//name[text()=‘王五‘]";
//配合xPath找到单个节点对象
Element selectSingleNode = (Element) doc.selectSingleNode(path);
System.out.println(selectSingleNode.getName());
//找到根标签下的所有标签 selectNodes(path);配合xPath 找到多个节点
String path = "//student";
List<Node> selectNodes = doc.selectNodes(path);
for (Node node : selectNodes) {
System.out.println(node.getName());
}
还有很多种方法,可查阅官方文档
原文:http://12983104.blog.51cto.com/12973104/1974526