Круто:Правильный синтаксис XMLSlurper для поиска элементов с заданным атрибутом.
-
01-07-2019 - |
Вопрос
Дан HTML-файл со структурой html -> тело -> куча divов Каков правильный оператор Groovy, чтобы найти все элементы div с непустым атрибутом тегов?
Не работает следующее:
def nodes = html.body.div.findAll { it.@tags != null }
потому что он находит все узлы.
Решение
Попробуйте следующее (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()
}
Это выводит:
test1
test4
Не связан с StackOverflow