0

0

GPath是什么 如何在Groovy中像操作对象一样操作XML

星降

星降

发布时间:2026-01-25 02:43:31

|

153人浏览过

|

来源于php中文网

原创

GPath是Groovy内置的路径表达式语法,专为遍历XmlSlurper/JsonSlurper解析后的嵌套数据设计,通过点号链式访问、@属性名、text()等实现简洁导航,区别于XPath和JSONPath。

gpath是什么 如何在groovy中像操作对象一样操作xml

什么是 GPath?它不是 XPath,也不是 JSONPath

GPath 是 Groovy 内置的路径表达式语法,专为遍历嵌套数据结构(如 XmlSlurper 解析后的 XML、JsonSlurper 解析后的 JSON、List/Map)设计。它看起来像属性访问,但背后是动态方法调用和重载操作符,不是标准规范,也不依赖外部引擎。

关键区别XPath 是通用查询语言,需显式调用 evaluate();而 GPath 在 Groovy 中直接作用于对象,比如 xml.book.author 会自动匹配所有 下的 节点,返回一个 NodeChild 列表。

用 XmlSlurper + GPath 读取 XML,就像在访问对象属性

XmlSlurper 是 Groovy 推荐的轻量级 XML 解析器,解析后返回可 GPath 导航的对象树。它默认忽略空白文本节点,适合快速提取内容。

常见操作包括:

  • 层级访问:用点号(.)逐级下钻,如 xml.root.child.grandchild
  • 同级多节点:直接写标签名,返回所有匹配子节点组成的列表(xml.item
  • 带条件筛选:用 find{}findAll{} 配合 GPath 表达式,如 xml.book.find{ it.@category == 'fiction' }
  • 属性访问:用 @属性名,如 book.@id 获取 的 id 值
  • 文本内容:用 text() 方法,如 author.text()
def xml = new XmlSlurper().parseText('''

  
    The Great Gatsby
    F. Scott Fitzgerald
  
  
    Sapiens
    Yuval Noah Harari
  

''')

// 获取所有书名
def titles = xml.book.title*.text()
// → ['The Great Gatsby', 'Sapiens']

// 找出 fiction 类别的书的作者
def fictionAuthors = xml.book.findAll{ it.@category == 'fiction' }.author*.text()
// → ['F. Scott Fitzgerald']

为什么不能直接用 XmlParser?GPath 支持差异在哪

XmlParser 返回的是标准 DOM-like Node 对象,不支持 GPath 的点号链式访问(如 node.book.title 会报 MissingPropertyException)。它更接近 Java 原生 XML 处理,适合需要修改节点、保留注释/命名空间等场景,但牺牲了 GPath 的简洁性。

AItools.fyi
AItools.fyi

找到让生活变得更轻松的最佳AI工具!

下载

如果你写了 new XmlParser().parse(...) 却想用 GPath,会遇到:

  • groovy.lang.MissingPropertyException: No such property: book for class: groovy.util.Node
  • it.@attr 不生效,必须改用 it.attribute('attr')
  • it.children() 才能拿到子节点,无法直接 it.child

所以:要 GPath,必须用 XmlSlurper;要精确控制或写回 XML,再考虑 XmlParser + 手动遍历。

容易踩的坑:空值、命名空间、延迟求值

GPath 看似简单,但 Groovy 的动态性和懒加载特性会让一些行为出人意料:

  • 空节点返回空列表而非 null:即使 xml.nonexistent 没有匹配项,也返回空 NodeChild 列表,不会 NPE,但 text() 会返回空字符串,size() 是 0 —— 别用 == null 判断是否存在
  • 命名空间需显式声明:带 namespace 的 XML(如 )必须用 new XmlSlurper(false, true) 关闭命名空间感知,或用 declareNamespace 注册前缀,否则 GPath 匹配失败
  • 延迟求值(lazy evaluation)xml.book 不是立即执行,而是返回一个代理对象;只有调用 text()size() 或参与迭代时才真正解析。这在循环中重复调用 xml.book 是安全的,但不要误以为它是“缓存结果”

最常被忽略的一点:GPath 表达式本身不抛异常,错误只在你试图从空结果调用方法时暴露(比如对空列表调 [0].text()),建议用 ?.text() 或先检查 size() > 0

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

845

2023.06.15

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

743

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

740

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

397

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

400

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

447

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

431

2023.08.02

java在线网站
java在线网站

Java在线网站是指提供Java编程学习、实践和交流平台的网络服务。近年来,随着Java语言在软件开发领域的广泛应用,越来越多的人对Java编程感兴趣,并希望能够通过在线网站来学习和提高自己的Java编程技能。php中文网给大家带来了相关的视频、教程以及文章,欢迎大家前来学习阅读和下载。

16947

2023.08.03

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

25

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 2.8万人学习

C# 教程
C# 教程

共94课时 | 7.5万人学习

Java 教程
Java 教程

共578课时 | 50.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号