I have a little xml-parsing problem with Groovy.
This is, what my data looks like:
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
...
I need ID, sID and d1.
What I get:
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>
What I want:
<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>
That’s part of my code:
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)
}
}
}
}
I want to keep it as simple as possible. So what I need is a statement like ‘if here starts a new regExId then start a new xml-block’, so that I can easily add new parts of the data (like d2) as needed. There is no existing xml-file.
Thanks for any information!
This is what I came up with: