Groovy: sintaxe correta para XmlSlurper para encontrar elementos com um determinado atributo

StackOverflow https://stackoverflow.com/questions/100325

  •  01-07-2019
  •  | 
  •  

Pergunta

Dado um arquivo HTML com a estrutura html -> corpo? -> um monte de divs o que é a declaração Groovy correta para encontrar todos os divs com um atributo não Tag em branco

O seguinte não está funcionando:

def nodes = html.body.div.findAll { it.@tags != null }

porque ele encontra todos os nós.

Foi útil?

Solução

Tente o seguinte (Groovy 1.5.6):

def doc = """
<html>
    <body>
        <div tags="1">test1</div>
        <div>test2</div>
        <div tags="">test3</div>
        <div tags="4">test4</div>
    </body>
</html>
"""

def html = new XmlSlurper().parseText( doc)

html.body.div.findAll { it.@tags.text()}.each { div ->
    println div.text()
}

Esta saídas:

test1
test4
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top