我正在用xmlslurper(groovy 1.7.4)解析一些xml,我需要删除一个标记(不要让它变成空的!)。下面是一个代码示例,说明了这一点:
import groovy.xml.StreamingMarkupBuilder
def CAR_RECORDS = '''
<records>
<car name='HSV Maloo' make='Holden' year='2006'>
<country>Australia</country>
<record type='speed'>Production Pickup Truck with speed of 271kph</record>
</car>
<car name='P50' make='Peel' year='1962'>
<country>Isle of Man</country>
<record type='size'>Smallest Street-Legal Car at 99cm wide and 59 kg in weight</record>
</car>
<car name='Royale' make='Bugatti' year='1931'>
<country>France</country>
<record type='price'>Most Valuable Car at $15 million</record>
</car>
</records>
'''
def records = new XmlSlurper().parseText(CAR_RECORDS)
def allRecords = records.car
assert 3 == allRecords.size()
def firstRecord = records.car[0]
assert 'car' == firstRecord.name()
println 'country before: ' + firstRecord.'country'.text()
firstRecord.'country'.replaceNode {}
println 'country after: ' + firstRecord.'country'.text()
这张照片
country before: Australia
country after: Australia
在xmlslurper中,没有firstrecord.remove('country')
我真的很困惑。这是一件显而易见的事情…
最佳答案
如果在调用replacenode之后从slurper中打印出xml:
import groovy.xml.XmlUtil
// ... your code here, followed by: ...
println XmlUtil.serialize(new StreamingMarkupBuilder().bind {
mkp.yield records
} )
国家节点似乎消失了:
<?xml version="1.0" encoding="UTF-8"?>
<records>
<car name="HSV Maloo" year="2006" make="Holden">
<record type="speed">Production Pickup Truck with speed of 271kph</record>
</car>
<car name="P50" year="1962" make="Peel">
<country>Isle of Man</country>
<record type="size">Smallest Street-Legal Car at 99cm wide and 59 kg in weight</record>
</car>
<car name="Royale" year="1931" make="Bugatti">
<country>France</country>
<record type="price">Most Valuable Car at $15 million</record>
</car>
</records>