我对 Groovy 有一点 xml 解析问题。
这就是我的数据的样子:
ID 001=1234
sID 001=q8b6v
d1 001=some Text
d2 001=more Text2
tzh 001=data
dse 001=data
ID 001=567823
sID 001=l3n37v2
d1 001=some Text
d2 001=more Text2
hrg 001=data
dfe 001=data
...
我需要 ID、sID 和 d1。
我得到什么:
What I get:
<add>
<doc>
<field name='ID'>00573419</field>
<field name='sID'>20120110572</field>
<field name='d1'>some Text</field>
<field name='ID'>00573406</field>
<field name='sID'>20120111110</field>
<field name='d1'>some Text2</field>
</doc>
</add>
我想要的是:
<add>
<doc>
<field name='ID'>00573419</field>
<field name='sID'>20120110572</field>
<field name='d1'>some Text</field>
</doc>
<doc>
<field name='ID'>00573406</field>
<field name='sID'>20120111110</field>
<field name='d1'>some Text2</field>
</doc>
</add>
这是我的代码的一部分:
if(!dataFile.exists()){
println "File does not exist!"
}else{
def key1, key2, key3, key4
def val1, val2, val3, val4
xml.add{
doc {
dataFile.eachLine {line ->
if(line.startsWith(regExId)){
(key1, val1) = line.split(/001=/).collect {it.trim()}
field(name:key1, val1)
}
if(line.startsWith(regExEntryId)){
(key2, val2) = line.split(/001=/).collect {it.trim()}
field(name:key2, val2)
}
if(line.startsWith(regExTitle)){
(key3, val3) = line.split(/001=/).collect {it.trim()}
field(name:key3, val3)
}
}
}
}
我想让它尽可能简单。所以我需要一个像'如果这里开始一个新的regExId然后开始一个新的xml块'这样的语句,这样我就可以根据需要轻松添加数据的新部分(如d2)。没有现有的 xml 文件。
感谢您提供任何信息!