Groovy的GPath表达式的完整语法是什么?

在尝试解析Groovy中的RSS源时,我发现使用通配符的GPath示例:

def text = """ 
<data> 
   <common-tables> 
    <table name="address"/> 
    <table name="phone"/> 
  </common-tables> 

  <special-tables> 
    <table name="person"/> 
  </special-tables> 

  <other-tables> 
    <table name="business"/> 
  </other-tables> 
</data> 
""" 

def xml = new XmlParser().parse(new ByteArrayInputStream(text.getBytes())) 
def tables = xml.'**'.table.findAll{ it.parent().name() == 
"special-tables" || it.parent().name

(从http://old.nabble.com/Q:-Avoiding-XPath—using-GPath-td19087210.html)

它看起来像是一个有趣的使用“扩展点”运算符.我在Groovy网站,书籍等上找不到任何参考.

这是如何工作的,更重要的是,你如何发现这一点?有没有XPath的GPath“Rosetta Stone”在那里?

解决方法

那么像往常一样,找到信息的最佳地方就是Groovy源码.
解析的结果是groovy.util.slurpersupport.GPathResult对象.

如果您查看源代码(普通java文件),您将看到getProperty(string)方法具有以下特殊运算符:

>“..”返回父级
>“*”返回所有的孩子
>“**”作为深度第一循环
>“@”用于访问属性
>正常节点存取器.

就是这样,暂时没有其他魔术关键词.

相关文章

背景:    8月29日,凌晨4点左右,某服务告警,其中一个...
https://support.smartbear.comeadyapi/docs/soapui/steps/g...
有几个选项可用于执行自定义JMeter脚本并扩展基线JMeter功能...
Scala和Java为静态语言,Groovy为动态语言Scala:函数式编程,...
出处:https://www.jianshu.com/p/ce6f8a1f66f4一、一些内部...
在运行groovy的junit方法时,报了这个错误:java.lang.Excep...