【Groovy】xml 序列化 ( 使用 MarkupBuilder 生成 xml 数据 | 设置 xml 标签内容 | 设置 xml 标签属性 )

简介: 【Groovy】xml 序列化 ( 使用 MarkupBuilder 生成 xml 数据 | 设置 xml 标签内容 | 设置 xml 标签属性 )

一、使用 MarkupBuilder 生成 xml 数据


生成


<student>
    <name code="utf-8">Tom</name>
    <age>18</age>
</student>


样式的 xml 文件 ,


首先 , 创建 FileWriter 对象 , 之后用于将生成的 xml 数据输出到文件中 ;


def fileWriter = new FileWriter(new File("a.xml"))


然后 , 创建 MarkupBuilder 对象 , 构造函数中传入 FileWriter 表示将 xml 文件写出到文件中 ;


// 创建 MarkupBuilder 对象
// 构造函数中传入 FileWriter 表示将 xml 文件写出到文件中
def markupBuilder = new MarkupBuilder(fileWriter)


最后 , 生成 xml 数据 ;


// 生成上述 xml 文件
markupBuilder.student{
    // 格式如下 :
    // xml 标签名称( 标签内容 , 标签属性 : 标签属性值)
    // 生成标签内容 : 标签内容直接写上即可
    // 生成标签属性 : 标签属性使用键值对方式生成
    name("Tom", code: "utf-8") {}
    age(18) {}
}



这里详细介绍下 xml 数据的生成过程 ,


markupBuilder.student

表示 , 生成的 xml 数据的根节点是  ,


xml 数据中的 标签 生成格式如下 :


xml 标签名称( 标签内容 , 标签属性 : 标签属性值)


生成标签内容 : 标签内容直接写在括号中即可 ; age(18){} 代码就可以生成 18 内容 ;


生成标签属性 : 标签属性使用键值对方式生成 ; name("Tom", code: "utf-8") {} 代码可以生成 Tom 内容 ;

二、完整代码示例


完整代码示例 :


import groovy.xml.MarkupBuilder
"""
<student>
    <name code="utf-8">Tom</name>
    <age>18</age>
</student>
"""
def fileWriter = new FileWriter(new File("a.xml"))
// 创建 MarkupBuilder 对象
// 构造函数中传入 FileWriter 表示将 xml 文件写出到文件中
def markupBuilder = new MarkupBuilder(fileWriter)
// 生成上述 xml 文件
markupBuilder.student{
    // 格式如下 :
    // xml 标签名称( 标签内容 , 标签属性 : 标签属性值)
    // 生成标签内容 : 标签内容直接写上即可
    // 生成标签属性 : 标签属性使用键值对方式生成
    name("Tom", code: "utf-8") {}
    age(18) {}
}


生成的 xml 文件如下 :


<student>
  <name code='utf-8'>Tom</name>
  <age>18</age>
</student>


下图中 , 右侧的 a.xml 就是生成的 xml 文件 ;

image.png


目录
相关文章
|
3月前
|
XML 存储 JSON
Twaver-HTML5基础学习(19)数据容器(2)_数据序列化_XML、Json
本文介绍了Twaver HTML5中的数据序列化,包括XML和JSON格式的序列化与反序列化方法。文章通过示例代码展示了如何将DataBox中的数据序列化为XML和JSON字符串,以及如何从这些字符串中反序列化数据,重建DataBox中的对象。此外,还提到了用户自定义属性的序列化注册方法。
49 1
|
4月前
|
XML 数据采集 存储
使用Java和XPath在XML文档中精准定位数据
在数据驱动的时代,从复杂结构中精确提取信息至关重要。XML被广泛用于数据存储与传输,而XPath则能高效地在这些文档中导航和提取数据。本文深入探讨如何使用Java和XPath精准定位XML文档中的数据,并通过小红书的实际案例进行分析。首先介绍了XML及其挑战,接着阐述了XPath的优势。然后,提出从大型XML文档中自动提取特定产品信息的需求,并通过代理IP技术、设置Cookie和User-Agent以及多线程技术来解决实际网络环境下的数据抓取问题。最后,提供了一个Java示例代码,演示如何集成这些技术以高效地从XML源中抓取数据。
175 7
使用Java和XPath在XML文档中精准定位数据
|
1月前
|
Java Maven
maven项目的pom.xml文件常用标签使用介绍
第四届人文,智慧教育与服务管理国际学术会议(HWESM 2025) 2025 4th International Conference on Humanities, Wisdom Education and Service Management
125 8
|
1月前
|
JSON 数据格式 索引
Python中序列化/反序列化JSON格式的数据
【11月更文挑战第4天】本文介绍了 Python 中使用 `json` 模块进行序列化和反序列化的操作。序列化是指将 Python 对象(如字典、列表)转换为 JSON 字符串,主要使用 `json.dumps` 方法。示例包括基本的字典和列表序列化,以及自定义类的序列化。反序列化则是将 JSON 字符串转换回 Python 对象,使用 `json.loads` 方法。文中还提供了具体的代码示例,展示了如何处理不同类型的 Python 对象。
|
23天前
|
XML JSON Kubernetes
什么是 YAML?:一种简洁高效的数据序列化格式
什么是 YAML?:一种简洁高效的数据序列化格式
87 0
|
3月前
|
JSON 缓存 NoSQL
redis序列化数据时,如何包含clsss类型信息?
通过配置 `com.fasterxml.jackson.databind.ObjectMapper` 的 `enableDefaultTyping` 方法,可以使序列化后的 JSON 包含类信息。
56 2
|
4月前
|
XML 数据格式 Python
将xml标签转换为txt(voc格式转换为yolo方便进行训练)
该文章提供了一个Python脚本,用于将VOC格式的XML标签文件转换为YOLO训练所需的TXT格式,包括修改数据集类别、输入图像与标注文件夹地址、转换过程和结果展示。
将xml标签转换为txt(voc格式转换为yolo方便进行训练)
|
2月前
|
XML Web App开发 数据格式
HTML 页面显示 XML 数据
10月更文挑战第2天
|
2月前
|
XML JSON 前端开发
C#使用HttpClient四种请求数据格式:json、表单数据、文件上传、xml格式
C#使用HttpClient四种请求数据格式:json、表单数据、文件上传、xml格式
514 0
|
4月前
|
存储 C# 数据库
解决C#对Firebase数据序列化失败的难题
在游戏开发中,Unity结合Firebase实时数据库为开发者提供强大支持,但在C#中进行数据序列化和反序列化时常遇难题。文章剖析了数据丢失或反序列化失败的原因,并给出解决方案,包括使用`JsonUtility`、确保字段标记为`[Serializable]`以及正确配置网络请求。示例代码演示了如何在Unity环境中实现Firebase数据的序列化和反序列化,并通过设置代理IP、Cookies和User-Agent来增强网络请求的安全性。这些技巧有助于确保数据完整传输,提升开发效率。
解决C#对Firebase数据序列化失败的难题