2

给定一个漂亮、简单的 XML 结构,XmlSlurper() 可以让我非常轻松地从中读取值。

def xml = "<html><head><title>groovy</title></head></html>"

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

println html.head.title

有没有办法让通用(基于类型等)XML 的这种简单的树导航成为可能。理想情况下,在下面的代码片段中,我想通过它们的name属性来遍历这些值,但是,我必须进行所有这些搜索:

def genxml = """
<doc>
    <lst name = "head">
        <str name = "title">groovy</str>
        <str name = "keywords">java xml</str>
    </lst>
</doc>"""

def doc = new XmlSlurper().parseText(genxml)
println doc.lst.find { it.@name == "head" }.str.find { it.@name == "title" }

有没有办法像这样走路:

println doc.head.title
4

1 回答 1

0

head 和 title 是属性。

slurper 和解析器之间有一些非常细微的区别:http: //www.ibm.com/developerworks/java/library/j-pg05199/

你可以这样做:

println "${doc.lst.str[0]} ${doc.lst.str[0].@name}"
println doc.lst.str.each { 
    println "${it} ${it.@name}"
    }

但看看输出:

groovy title
groovy title
java xml keywords
groovyjava xml
于 2009-06-27T01:16:47.690 回答