文章目录
- 一、删除 Xml 文件中的节点
- 二、增加 Xml 文件中的节点
- 三、将修改后的 Xml 数据输出到文件中
- 四、完整代码示例
一、删除 Xml 文件中的节点
在 【Groovy】Xml 反序列化 ( 使用 XmlParser 解析 Xml 文件 | 获取 Xml 文件中的节点和属性 | 获取 Xml 文件中的节点属性 ) 博客基础上 , 删除 Xml 文件中的节点信息 ;
下面是要解析的 xml 文件 :
代码语言:javascript复制<?xml version='1.0' encoding='UTF-8'?>
<student>
<name code="utf-8">Tom</name>
<age>18</age>
<team>
<member>Jerry</member>
</team>
</student>
获取 age 节点 , 删除子节点 , 需要通过父节点进行删除 , 调用 xmlParser 对象 ( 根节点 ) 的 remove 方法 , 删除二级节点 age 节点 ;
代码语言:javascript复制// 获取 age 节点
Node ageNode = xmlParser.age[0]
// 从根节点中删除 age 节点
xmlParser.remove(ageNode)
二、增加 Xml 文件中的节点
增加 Xml 文件中的节点 , 调用 appendNode 方法 , 可以向节点插入一个子节点 ;
代码语言:javascript复制// 添加节点
xmlParser.appendNode("height", "175cm")
三、将修改后的 Xml 数据输出到文件中
创建 XmlNodePrinter
对象 , 并调用该对象的 print 方法 , 传入 XmlParser 对象 , 可以将该 XmlParser 数据信息写出到文件中 ;
// 将修改后的 Xml 节点输出到目录中
new XmlNodePrinter(new PrintWriter(new File("b.xml"))).print(xmlParser)
四、完整代码示例
完整代码示例 :
代码语言:javascript复制import groovy.xml.XmlNodePrinter
// 要解析的 xml 文件
def xmlFile = new File("a.xml")
// 创建 Xml 文件解析器
def xmlParser = new XmlParser().parse(xmlFile)
// 获取 xml 文件下的 <name> 节点
// <name> 节点位于根节点下, 可以直接获取
// 获取的 <name> 节点是一个数组
// 如果只有一个该节点, 可以直接获取第 0 个元素即可
println xmlParser.name
println xmlParser.name[0]
// 获取 <team> 节点 下的 <member> 节点, 获取的是数组
// 也是获取第 0 个元素
println xmlParser.team[0].member[0]
// 获取 name 节点
Node nameNode = xmlParser.name[0]
// 获取 Activity 节点的属性 , 这是一个 map 集合
println nameNode.attributes()
// 获取 age 节点
Node ageNode = xmlParser.age[0]
// 从根节点中删除 age 节点
xmlParser.remove(ageNode)
// 添加节点
xmlParser.appendNode("height", "175cm")
// 将修改后的 Xml 节点输出到目录中
new XmlNodePrinter(new PrintWriter(new File("b.xml"))).print(xmlParser)
执行结果 :
代码语言:javascript复制[name[attributes={code=utf-8}; value=[Tom]]]
name[attributes={code=utf-8}; value=[Tom]]
member[attributes={}; value=[Jerry]]
[code:utf-8]