3

寻找 GPath 表达式以使用属性名称获取属性值列表:

def xmltxt = """<reports>
    <report category="weather">sunny</report>
    <report category="sports">golf</report>
    <report category="business">
      <subreport category="deals">wallstreet</subreport>
    </report>
    <report>NA</report>
    <report category="life">gossip</report>
 </reports>"""

..当搜索所有category属性时,我想取回这个,不管category文档中存在属性的位置:

[weather, sports, business, deals, life]

...但是我所有的尝试都比我想要的要多,似乎它正在返回没有category属性的节点;我可以从列表中删除空元素,但我想知道为什么会这样。

[, weather, sports, business, deals, , life]

  def names = xml.'**'.findAll{
     it.@category        
  }.collect{
     it.@category
  }
4

1 回答 1

4
def parsed = new XmlParser().parseText( xmltxt )
parsed.'**'*.attribute( 'category' ).findAll()

应该做。

给你,XmlSlurper解决方案:

def parsed = new XmlSlurper().parseText( xmltxt )
parsed.'**'*.attributes().findResults { it.category }
于 2014-06-01T02:22:50.407 回答