尝试remove xml
使用groovy
. 这里要删除requiredByDate
元素,该元素多次出现并且具有带前缀的 namcespace。
看了很多网上的例子,还有stackover。其中一些很接近。如果该 xml 元素没有命名空间,则获取所需的输出。
问题是xml 元素具有命名空间并且无法达到预期的效果。
这是我正在尝试的 groovy 脚本:
import groovy.xml.*
def x='''<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:com="http://www.example/test/commontypes" xmlns:ord="http://www.example/test/orderservice" xmlns:ord1="http://www.example/test/order">
<soapenv:Header/>
<soapenv:Body>
<ord:orderRequest>
<ord1:orderRef>${#TestCase#ORDERREF}</ord1:orderRef>
<ord1:header>
<ord1:description>user test</ord1:description>
<ord1:customerID></ord1:customerID>
<ord1:requiredByDate>2010-02-02T12:00:00-07:00</ord1:requiredByDate>
</ord1:header>
<ord1:line>
<ord1:lineNumber>1</ord1:lineNumber>
<ord1:actionMode>mode1</ord1:actionMode>
<ord1:requiredByDate>2010-02-02T12:00:00-07:00</ord1:requiredByDate>
</ord1:line>
<ord1:line>
<ord1:lineNumber>2</ord1:lineNumber>
<ord1:action>userAction</ord1:action>
<ord1:requiredByDate>2010-02-02T12:00:00-07:00</ord1:requiredByDate>
</ord1:line>
</ord:orderRequest>
</soapenv:Body>
</soapenv:Envelope>'''
def xml=new XmlParser().parseText(x)
def nodes = xml.'**'.findAll{ it.name() == 'requiredByDate' }
nodes.each{it.parent().remove(it)}
XmlUtil.serialize(xml).toString()
输出与输入相同,即不删除requiredByDate
元素(在 xml 中出现 3 次)
如果我使用命名空间 ie, 进行硬编码'ord1:requiredByDate'
,则会出现所需的输出。参考xml.'**'.findAll{ it.name() == 'ord1:requiredByDate' }
这里。
但是,我不知道运行时 xml 中有什么前缀。因此,不能使用findAll
上面的硬编码前缀。