【Groovy】Xml 反序列化 ( 使用 XmlParser 解析 Xml 文件 | 删除 Xml 文件中的节点 | 增加 Xml 文件中的节点 | 将修改后的 Xml 数据输出到文件中 )

2023-03-30 11:12:43 浏览数 (1)

文章目录

  • 一、删除 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 数据信息写出到文件中 ;

代码语言:javascript复制
// 将修改后的 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]

0 人点赞