Разбор XML с многострочными записями
Вопрос
Я хотел бы взять XML в формате ниже и загрузить каждую запись кода в объект домена в моем BootStrap.groovy
. Я хочу сохранить форматирование каждого фрагмента кода. Р>
XML
<records>
<code>
<language>Groovy</language>
<snippet>
println "This is Groovy"
println "A very powerful language"
</snippet>
</code>
<code>
<language>Groovy</language>
<snippet>
3.times {
println "hello"
}
</snippet>
</code>
<code>
<language>Perl</language>
<snippet>
@foo = split(",");
</snippet>
</code>
</records>
Доменный объект
Code {
String language
String snippet
}
BootStrap.groovy
new Code(language l, snippet: x).save()
Решение
примерно как то так:
def CODE_XML = '''
<records>
<code>
<language>Groovy</language>
<snippet>
println "This is Groovy"
println "A very powerful language"
</snippet>
</code>
<code>
<language>Groovy</language>
<snippet>
3.times {
println "hello"
}
</snippet>
</code>
<code>
<language>Perl</language>
<snippet>
@foo = split(",");
</snippet>
</code>
</records>
'''
def records = new XmlParser().parseText(CODE_XML)
records.code.each() { code ->
new Code(language: code.language, snippet: code.snippet).save()
}
Другие советы
Если вы можете специфицировать DTD или подобное, и ваш синтаксический анализатор XML подчиняется ему, я думаю, вы можете указать содержимое элемента сниппета как CDATA и всегда получать его как есть.
Попробуйте добавить атрибут xml:space="preserve"
к <snippet>
элементам.
Не связан с StackOverflow