(三)XML基础(3):Xpath
五、XPath:快速定位到节点
5.1 简介


5.2 语法

5.3 案例
- XPath对有命名空间的xml文件和没有命名空间的xml定位节点的方法是不一样的,所以再对不同的xml需要进行不同的处理。
- 使用前提: 导入

- Test_Xpath.java
package dom; import java.io.File;
import java.util.HashMap;
import java.util.List;
import java.util.Map; import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader; public class Test_Xpath { public static void main(String[] args) {
// Test_Xpath.testNo_Namespace();
Test_Xpath.test_Namespace(); } /**
* 搜索有命名空间的xml文件
*/
private static void test_Namespace() { File xmlFile=new File("./src/student.xml");
SAXReader saxReader=new SAXReader();
Map<String,String> namespaceURIs=new HashMap<String, String>(); /**
* 设置命名空间,注意在xml文件中命名空间的前缀可以为空(xmlns="http://www.example.org/student")
* 但是在这里不能为空,必须有前缀
*/
namespaceURIs.put("stu", "http://www.example.org/student");
namespaceURIs.put("jdbc","http://www.example.org/jdbc");
saxReader.getDocumentFactory().setXPathNamespaceURIs(namespaceURIs);
try {
Document document=saxReader.read(xmlFile); Element rootElment=document.getRootElement();
Element parentElement=rootElment.element("root"); /**
* 从document节点开始搜索——绝对路径 "/other/root/student"
* 中以/打头表示以绝对路径方法,而这个xml文件里的根节点为other,
* 这里的other、root、student节点都是stu命名空间的xml文件里的,所以要加stu前缀
*/
List<Element> list = document.selectNodes("/stu:other/stu:root/stu:student");
// System.out.println(list.size()); /**
* 从other路径搜索——相对路径
*/
list = rootElment.selectNodes("stu:root/stu:student");
// System.out.println(list.size()); /**
* 从root目录(parentElement节点)搜索起_全文路径,
* 这里的parentElemen换成其他节点比如document或者rootElement也是可以的,
* 只要这个节点是被搜索节点的父节点即可
*/
list = parentElement.selectNodes("//stu:student");
// System.out.println(list.size()); /**
* 找到属性id=03的节点
*/
list = parentElement.selectNodes("/stu:other/stu:root/stu:student[@id=03]");
Element element_id03 = list.get(0);
// System.out.println(element_id03.element("name").getText()); /**
* 查找性别为男的节点,没有加@的就是指元素节点的值,加了@是指节点的属性的值
* 属性不用加前缀外,元素节点必须加前缀
*/
list = parentElement.selectNodes("stu:student[stu:sex='男']");
// System.out.println(list.size()); /**
* 查找年龄在某一范围的节点
*/
list = parentElement.selectNodes("stu:student[stu:age>=15 and stu:age<50]");
// System.out.println(list.size()); /**
* 查找名称中有a字符的节点,相当于sql中的模糊查询(like),
* xpath中也有函数,这里的contains(name,'张三') 就是一个函数,
* student[contains(name,'张三')] :
* 表示查找子节点为name且name的值含有‘张三’的student节点
*/
list = parentElement.selectNodes("stu:student[contains(stu:name,'张三')]");
// System.out.println(list.size()); /**
* 查找名称为包含a的字符,并且性别为男的,并且年龄在一个范围内
*/
list = parentElement.selectNodes("stu:student[contains(stu:name,'张三') and stu:sex='男' and stu:age>=10 ]");
// System.out.println(list.size()); Element jdbcElement=(Element)document.selectSingleNode("/stu:other/jdbc:jdbcInfo"); System.out.println(jdbcElement.elementText("jdbcDriver"));
System.out.println(jdbcElement.elementText("url"));
System.out.println(jdbcElement.elementText("password"));
System.out.println(jdbcElement.elementText("user")); } catch (DocumentException e) {
e.printStackTrace();
} } /**
* 搜索没有命名空间的xml文件
*/
private static void testNo_Namespace() {
File xmlFile = new File("./src/no_namespace.xml"); SAXReader saxReader = new SAXReader(); try {
Document document = saxReader.read(xmlFile); Element rootElment = document.getRootElement(); Element parentElement = (Element) rootElment.elements("root").get(0); /**
* 从document节点开始搜索——绝对路径 "/other/root/student"
* 中以/打头表示以绝对路径方法,而这个xml文件里的根节点为other
*/
List<Element> list = document.selectNodes("/other/root/student");
// System.out.println(list.size()); /**
* 从other路径搜索——相对路径
*/
list = rootElment.selectNodes("root/student");
// System.out.println(list.size()); /**
* 从root目录(parentElement节点)搜索起_全文路径,
* 这里的parentElemen换成其他节点比如document或者rootElement也是可以的,
* 只要这个节点是被搜索节点的父节点即可
*/
list = parentElement.selectNodes("//student");
// System.out.println(list.size()); /**
* 找到属性id=03的节点
*/
list = parentElement.selectNodes("/other/root/student[@id=03]");
Element element_id03 = list.get(0);
// System.out.println(element_id03.element("name").getText()); /**
* 查找性别为男的节点,没有加@的就是指元素节点的值,加了@是指节点的属性的值
*/
list = parentElement.selectNodes("student[sex='男']");
// System.out.println(list.size()); /**
* 查找年龄在某一范围的节点
*/
list = parentElement.selectNodes("student[age>=15 and age<50]");
// System.out.println(list.size()); /**
* 查找名称中有a字符的节点,相当于sql中的模糊查询(like),
* xpath中也有函数,这里的contains(name,'张三') 就是一个函数,
* student[contains(name,'张三')] :
* 表示查找子节点为name且name的值含有‘张三’的student节点
*/
list = parentElement.selectNodes("student[contains(name,'张三')]");
// System.out.println(list.size()); /**
* 查找名称为包含a的字符,并且性别为男的,并且年龄在一个范围内
*/
list = parentElement.selectNodes("student[contains(name,'张三') and sex='男' and age>=10 ]");
System.out.println(list.size()); } catch (DocumentException e) {
e.printStackTrace();
} }
}
- student.xml
<?xml version="1.0" encoding="UTF-8"?> <other xmlns="http://www.example.org/student" xmlns:jdbc="http://www.example.org/jdbc"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.example.org/student student.xsd http://www.example.org/jdbc jdbc.xsd ">
<root>
<student id="01">
<name>张三</name>
<age>15</age>
<sex>男</sex>
<content>张三备注</content>
</student>
<student id="02">
<name>被修改后的张三</name>
<age>25</age>
<sex>女</sex>
<content>李四备注</content>
</student>
<student id="03">
<name>新增</name>
<age>12</age>
<sex>男</sex>
<content><![CDATA[#$%^#$%#$^]]></content>
</student>
</root>
<jdbc:jdbcInfo>
<jdbc:jdbcDriver>com.mysql.jdbc.Driver</jdbc:jdbcDriver>
<jdbc:url>jdbc:mysql://127.0.0.1:3306/user?useUnicode=true&characterEncoding=UTF-8</jdbc:url>
<jdbc:user>root</jdbc:user>
<jdbc:password></jdbc:password>
</jdbc:jdbcInfo>
</other>
- no_namespace.xml
<?xml version="1.0" encoding="UTF-8"?> <other >
<root>
<student id="01">
<name>张三</name>
<age>15</age>
<sex>男</sex>
<content>张三备注</content>
</student>
<student id="02">
<name>被修改后的张三</name>
<age>25</age>
<sex>女</sex>
<content>李四备注</content>
</student>
<student id="03">
<name>新增</name>
<age>12</age>
<sex>男</sex>
<content><![CDATA[#$%^#$%#$^]]></content>
</student> </root>
</other>
(三)XML基础(3):Xpath的更多相关文章
- XML 参考:XML基础 XML 简介
XML 参考:XML基础 -- XML简介和用途 转:http://www.cnblogs.com/Dlonghow/archive/2009/01/22/1379799.html XML 参考:XM ...
- XML基础+Java解析XML +几种解析方式的性能比较
XML基础+Java解析XML 一:XML基础 XML是什么: 可扩展的标记语言 XML能干什么: 描述数据.存储数据.传输(交换)数据. XML与HTML区别: 目的不一样 XML 被设计用来描述数 ...
- XML基础介绍【二】
XML基础介绍[二] 1.schema约束dtd语法: <!ELEMENT 元素名称 约束>schema符合xml的语法,xml语句.一个xml中可以有多个schema,多个schema使 ...
- .net学习笔记---xml基础知识
一.XML简介 XML是一种标记语言,用于描述数据,它提供一种标准化的方式来来表示文本数据.XML文档以.xml为后缀.需要彻底注意的是XML是区分大小写的. 先从一个简单的XML例子来了解下xml基 ...
- XML基础概念
XML基础概念 一.什么是XML. 可扩展标记语言(EXtensible Markup Language),标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言. 二.XML特点 1 ...
- 转载---SQL Server XML基础学习之<5>--XQuery(query)
本章写一些SQL Server XML的一些XQuery基础语法,主要讲的query查询语法 T-SQL 支持用于查询 XML 数据类型的 XQuery 语言的子集. XQuery 基于现有的 XPa ...
- XML基础<第一篇>
一.XML简介 XML是一种标记语言,用于描述数据,它提供一种标准化的方式来来表示文本数据.XML文档以.xml为后缀.需要彻底注意的是XML是区分大小写的. 先从一个简单的XML例子来了解下xml基 ...
- 【二十八】xml编程(dom\xpath\simplexml)
1.xml基础概念 作用范围: 作为程序通讯的标准. 作为配置文件. 作为小型数据库. xml语法: <根标签> <标签 元素="元素值" ...>< ...
- 第一篇 -- XML基础
一.XML简介 XML是一种标记语言,用于描述数据,它提供一种标准化的方式来来表示文本数据.XML文档以.xml为后缀.需要彻底注意的是XML是区分大小写的. 先从一个简单的XML例子来了解下xml基 ...
随机推荐
- 制作A4纸打印的网页像素大小设置(转)
公司内做系统,要用A4纸打印东西,A4纸标准时mm,换算成像素不知道.网上找找,找到一篇文章,转一下,备用. A4纸的尺寸是210mm*297mm,也就是21.0cm*29.7cm,而1英寸=2.54 ...
- SQL-W3School-高级:SQL 数据库
ylbtech-SQL-W3School-高级:SQL 数据库 1.返回顶部 1. 现代的 SQL 服务器构建在 RDBMS 之上. DBMS - 数据库管理系统(Database Managemen ...
- HTML5 地理位置定位API(2)
HTML5 Geolocation API (地理位置应用程序接口) 目前PC浏览器支持情况: Firefox 3.5+Chrome 5.0+Safari 5.0+Opera 10.60+Intern ...
- ASP程序中调用Now()总显示“上午”和“下午”,如何解决?
ASP程序中调用Now()总显示这样的格式:“2007-4-20 下午 06:06:38”,我要的正确格式为“2007-4-20 18:06:38”,我已经通过控制面板==>区域和语言选项==& ...
- Yarn概述——FAST, RELIABLE, AND SECURE DEPENDENCY MANAGEMENT
官网链接:https://yarnpkg.com/lang/en/ 特性 Ultra Fast. Yarn caches every package it downloads so it never ...
- 阶段5 3.微服务项目【学成在线】_day09 课程预览 Eureka Feign_05-Feign远程调用-客户端负载均衡介绍
2 Feign远程调用 在前后端分离架构中,服务层被拆分成了很多的微服务,服务与服务之间难免发生交互,比如:课程发布需要调用 CMS服务生成课程静态化页面,本节研究微服务远程调用所使用的技术. 下图是 ...
- VM12_pro+Ubuntu16_64+Qt5.12.2环境搭建
1.准备软件[已经存网盘] 2.安装Vm 3.安装Ubuntu 4.进入linux,修改Qt安装包权限 5.运行Qt 6.第五步会弹出Qt安装的界面,默认安装就行了 7.修改环境变量 sudo ged ...
- jmeter 随机取一个值的方法
1.添加用户自定义变量 在要用到随机值的地方写入 ${__RandomFromMultipleVars(1|2|0)} 例子: 效果:
- jsPlumb 基本概念
jsPlumb 基本概念 一.默认属性 Anchor:锚点(连接点位置),可以设置在任何没有锚点的目标上(endPoint) Anchors:设置在connect的源和目标点的连接点位置,默认是 Bo ...
- C#数字除法
C#中计算double a=1/1000:应该结果是0.001,但为什么会变成0呢? C# 中 如果相除的两个数都是整数(int 型) 那么除的结果就是只取整数部分 所以你才会取到0 如果你要取精确的 ...