JavaWeb学习-XML系列-5-XML之XPath解析

2024-06-11 11:08

本文主要是介绍JavaWeb学习-XML系列-5-XML之XPath解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

上一篇学习了DOM4J里面的常见的解析文件和如何写一个xml文件内容。其实DOM4J这个开源的工具除了支持DOM解析之外,它还支持XPath解析,XPath解析也经常使用。这一篇,我们就来学习下如何通过xpath表达式来得到xml里面的内容。我们在Selenium UI自动化学习的时候经常使用xpath来定位元素,同样在一个xml里面,其实就是一个DOM树,从根节点开始,我们也可以通过路径的方式去获取某一个元素的值,这就是xpath解析。如果你做的一个服务器的接口测试,返回的数据是xml文件类型,那么你在断言的时候,使用XPath就很简单。

1.环境准备

准备把一个xml内容放在项目根目录

<?xml version="1.0" encoding="UTF-8"?>
<students><student number="j2ee_0001"><name>张三</name><age>18</age><gender>male</gender></student><student number="j2ee_0002"><name>李四</name><age>19</age><gender>female</gender></student>
</students>

2.在一个包下写一个Junit的类

我这里写一个方法,去拿到第二个学生的名称是不是李四

package com.anthony.parse;import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;
import org.junit.Test;public class ParseByXPathTest {@Testpublic void test1() throws DocumentException {SAXReader reader = new SAXReader();Document doc = reader.read("student.xml");//parse by xpath to get TextNode node = doc.selectSingleNode("/students/student[2]/name");System.out.println(node.getText());}}

运行结果报错

java.lang.NoClassDefFoundError: org/jaxen/JaxenException

这个提示没定义这样的类,缺少的这个东西叫jaxen, 原来,我们项目build path下的lib光有dom4j的jar还是不行,还需要一个jaxen-xxx.jar的文件,我们去maven的网站去找一下https://mvnrepository.com/artifact/jaxen/jaxen/1.1.1

然后添加到项目的build path中去,再次运行就能输出结果。

李四

下面再举例一个如何获取某一个标签的属性值。

package com.anthony.parse;import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;
import org.junit.Test;public class ParseByXPathTest {@Testpublic void test1() throws DocumentException {SAXReader reader = new SAXReader();Document doc = reader.read("student.xml");//parse by xpath to get TextNode node = doc.selectSingleNode("/students/student[2]/name");System.out.println(node.getText());}@Testpublic void test2() throws DocumentException {SAXReader reader = new SAXReader();Document doc = reader.read("student.xml");//parse by xpath to get attribute valueNode node = doc.selectSingleNode("/students/student[2]");System.out.println(node.getText());System.out.println(node.valueOf("@number"));}}

上面的test2就是来获取属性number的值

	
j2ee_0002

从上面的例子来看,如果只是拿到某一些标签的文本或者标签内属性的值,我还是喜欢通过XPath的方式,代码简单。当然我上面还有一个方法没有介绍,那就是获取一组标签doc.selectNodes(xpath),有兴趣可以通过这个方法,获取两个student,xpath这样写/students/student  就能得到一个Node对象列表。

 

这篇关于JavaWeb学习-XML系列-5-XML之XPath解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1050999

相关文章

Java+AI驱动实现PDF文件数据提取与解析

《Java+AI驱动实现PDF文件数据提取与解析》本文将和大家分享一套基于AI的体检报告智能评估方案,详细介绍从PDF上传、内容提取到AI分析、数据存储的全流程自动化实现方法,感兴趣的可以了解下... 目录一、核心流程:从上传到评估的完整链路二、第一步:解析 PDF,提取体检报告内容1. 引入依赖2. 封装

使用Spring Cache本地缓存示例代码

《使用SpringCache本地缓存示例代码》缓存是提高应用程序性能的重要手段,通过将频繁访问的数据存储在内存中,可以减少数据库访问次数,从而加速数据读取,:本文主要介绍使用SpringCac... 目录一、Spring Cache简介核心特点:二、基础配置1. 添加依赖2. 启用缓存3. 缓存配置方案方案

Java实现复杂查询优化的7个技巧小结

《Java实现复杂查询优化的7个技巧小结》在Java项目中,复杂查询是开发者面临的“硬骨头”,本文将通过7个实战技巧,结合代码示例和性能对比,手把手教你如何让复杂查询变得优雅,大家可以根据需求进行选择... 目录一、复杂查询的痛点:为何你的代码“又臭又长”1.1冗余变量与中间状态1.2重复查询与性能陷阱1.

深度剖析SpringBoot日志性能提升的原因与解决

《深度剖析SpringBoot日志性能提升的原因与解决》日志记录本该是辅助工具,却为何成了性能瓶颈,SpringBoot如何用代码彻底破解日志导致的高延迟问题,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言第一章:日志性能陷阱的底层原理1.1 日志级别的“双刃剑”效应1.2 同步日志的“吞吐量杀手”

Spring创建Bean的八种主要方式详解

《Spring创建Bean的八种主要方式详解》Spring(尤其是SpringBoot)提供了多种方式来让容器创建和管理Bean,@Component、@Configuration+@Bean、@En... 目录引言一、Spring 创建 Bean 的 8 种主要方式1. @Component 及其衍生注解

SpringBoot通过main方法启动web项目实践

《SpringBoot通过main方法启动web项目实践》SpringBoot通过SpringApplication.run()启动Web项目,自动推断应用类型,加载初始化器与监听器,配置Spring... 目录1. 启动入口:SpringApplication.run()2. SpringApplicat

Java利用@SneakyThrows注解提升异常处理效率详解

《Java利用@SneakyThrows注解提升异常处理效率详解》这篇文章将深度剖析@SneakyThrows的原理,用法,适用场景以及隐藏的陷阱,看看它如何让Java异常处理效率飙升50%,感兴趣的... 目录前言一、检查型异常的“诅咒”:为什么Java开发者讨厌它1.1 检查型异常的痛点1.2 为什么说

基于Java开发一个极简版敏感词检测工具

《基于Java开发一个极简版敏感词检测工具》这篇文章主要为大家详细介绍了如何基于Java开发一个极简版敏感词检测工具,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录你是否还在为敏感词检测头疼一、极简版Java敏感词检测工具的3大核心优势1.1 优势1:DFA算法驱动,效率提升10

Java使用正则提取字符串中的内容的详细步骤

《Java使用正则提取字符串中的内容的详细步骤》:本文主要介绍Java中使用正则表达式提取字符串内容的方法,通过Pattern和Matcher类实现,涵盖编译正则、查找匹配、分组捕获、数字与邮箱提... 目录1. 基础流程2. 关键方法说明3. 常见场景示例场景1:提取所有数字场景2:提取邮箱地址4. 高级

使用SpringBoot+InfluxDB实现高效数据存储与查询

《使用SpringBoot+InfluxDB实现高效数据存储与查询》InfluxDB是一个开源的时间序列数据库,特别适合处理带有时间戳的监控数据、指标数据等,下面详细介绍如何在SpringBoot项目... 目录1、项目介绍2、 InfluxDB 介绍3、Spring Boot 配置 InfluxDB4、I