groovy XmlSlurper解析XML

时间:2013-07-03 14:30:04

标签: groovy

我得到一个这样的XML文件:

<?xml version="1.0" encoding="UTF-8"?>
<soap:Envelope xmlns:soap="http://www.w3.org/2003/05/soap-envelope" xmlns:udb="http://somenamespace>
    <soap:Header/>
    <soap:Body>
        <udb:ProvideUDBIdentityInformationRequest>
            <udb:RequestID>1</udb:RequestID>
            <udb:IDnumber>1</udb:IDnumber>
            <udb:UnifiedNumber>3</udb:UnifiedNumber>
        </udb:ProvideUDBIdentityInformationRequest>
    </soap:Body>
</soap:Envelope> 

我想将下面的字符串保存到另一个文件中。

    <soap:Body>
        <udb:ProvideUDBIdentityInformationRequest>
            <udb:RequestID>1</udb:RequestID>
            <udb:IDnumber>1</udb:IDnumber>
            <udb:UnifiedNumber>3</udb:UnifiedNumber>
        </udb:ProvideUDBIdentityInformationRequest>
    </soap:Body>

我怎样才能实现这一目标? 事实上,我已经引用了一些像这样的教程http://groovy.codehaus.org/Reading+XML+using+Groovy%27s+XmlSlurper,但在XmlSlurper中找不到这样的方法。

提前致谢!

1 个答案:

答案 0 :(得分:2)

假设您在名为xml的变量中拥有原始xml,您可以执行以下操作:

String output = new groovy.xml.StreamingMarkupBuilder().bind {
    mkp.yield new XmlSlurper().parseText( xml ).Body
}

然后,output等于:

<soap:Body xmlns:soap='http://www.w3.org/2003/05/soap-envelope'>
    <udb:ProvideUDBIdentityInformationRequest xmlns:udb='http://somenamespace'>
        <udb:RequestID>1</udb:RequestID>
        <udb:IDnumber>1</udb:IDnumber>
        <udb:UnifiedNumber>3</udb:UnifiedNumber>
    </udb:ProvideUDBIdentityInformationRequest>
</soap:Body>