【Groovy】xml 序列化 ( 使用 StreamingMarkupBuilder 生成 xml 数据 | mkp.xmlDeclaration() 生成 xml 版本数据 )

简介: 【Groovy】xml 序列化 ( 使用 StreamingMarkupBuilder 生成 xml 数据 | mkp.xmlDeclaration() 生成 xml 版本数据 )

一、使用 StreamingMarkupBuilder 生成 xml 数据


在之前的博客中 , 使用 MarkupBuilder 生成 xml 数据 , 其原理是 DOM 解析 ;


使用 StreamingMarkupBuilder 生成 xml 数据 , 相当于 SAX 解析 ;


首先 , 创建 StreamingMarkupBuilder 对象 , 并设置 xml 文件的编码格式为 " UTF-8 " , 编码格式设置 streamingMarkupBuilder.encoding 成员即可 ;


// 创建 StreamingMarkupBuilder 对象
def streamingMarkupBuilder = new StreamingMarkupBuilder()
// 设置 xml 文件的编码格式为 UTF-8 格式
streamingMarkupBuilder.encoding = "UTF-8"


然后 , 定义闭包 , 在闭包中规定 xml 文件的生成格式 ; 该闭包中的 xml 定义形式 与 之前的 MarkupBuilder 闭包相同 ;


// 定义 xml 文件的闭包
def closure = {
    mkp.xmlDeclaration()
    student {
        // 格式如下 :
        // xml 标签名称( 标签内容 , 标签属性 : 标签属性值)
        // 生成标签内容 : 标签内容直接写上即可
        // 生成标签属性 : 标签属性使用键值对方式生成
        name("Tom", code: "utf-8") {
        }
        mkp.comment("学生姓名")
        age(18) {}
        mkp.comment("学生年龄")
        // 标签下创建子标签
        team() {
            member("Jerry") {}
        }
        mkp.comment("小组成员")
    }
}


最后 , 调用 streamingMarkupBuilder.bind(闭包) 方法 , 生成 xml 文件 ;


def xml = streamingMarkupBuilder.bind(closure)
println xml

二、mkp.xmlDeclaration() 生成 xml 版本数据


在闭包中 , 如果要定义 xml 版本 , 使用


mkp.xmlDeclaration()


代码 , 即可输出  内容 , 如果在 StreamingMarkupBuilder 对象中 , 设置了编码 ,


// 设置 xml 文件的编码格式为 UTF-8 格式
streamingMarkupBuilder.encoding = "UTF-8"


则会生成 如下 xml 文件头 ;


<?xml version='1.0' encoding='UTF-8'?>

三、完整代码示例


完整代码示例 :


import groovy.xml.StreamingMarkupBuilder
"""
<?xml version='1.0' encoding='UTF-8'?>
<student>
    <name code="utf-8">Tom</name>
    <age>18</age>
    <team>
        <member>Jerry</member>
    </team>
</student>
"""
// 创建 StreamingMarkupBuilder 对象
def streamingMarkupBuilder = new StreamingMarkupBuilder()
// 设置 xml 文件的编码格式为 UTF-8 格式
streamingMarkupBuilder.encoding = "UTF-8"
// 定义 xml 文件的闭包
def closure = {
    mkp.xmlDeclaration()
    student {
        // 格式如下 :
        // xml 标签名称( 标签内容 , 标签属性 : 标签属性值)
        // 生成标签内容 : 标签内容直接写上即可
        // 生成标签属性 : 标签属性使用键值对方式生成
        name("Tom", code: "utf-8") {
        }
        mkp.comment("学生姓名")
        age(18) {}
        mkp.comment("学生年龄")
        // 标签下创建子标签
        team() {
            member("Jerry") {}
        }
        mkp.comment("小组成员")
    }
}
def xml = streamingMarkupBuilder.bind(closure)
println xml


执行结果 :


<?xml version='1.0' encoding='UTF-8'?>
<student><name code='utf-8'></name><!--学生姓名--><age></age><!--学生年龄--><team><member></member></team><!--小组成员--></student>

image.png

目录
相关文章
|
1月前
|
存储 分布式计算 Java
|
24天前
|
XML 数据采集 存储
使用Java和XPath在XML文档中精准定位数据
在数据驱动的时代,从复杂结构中精确提取信息至关重要。XML被广泛用于数据存储与传输,而XPath则能高效地在这些文档中导航和提取数据。本文深入探讨如何使用Java和XPath精准定位XML文档中的数据,并通过小红书的实际案例进行分析。首先介绍了XML及其挑战,接着阐述了XPath的优势。然后,提出从大型XML文档中自动提取特定产品信息的需求,并通过代理IP技术、设置Cookie和User-Agent以及多线程技术来解决实际网络环境下的数据抓取问题。最后,提供了一个Java示例代码,演示如何集成这些技术以高效地从XML源中抓取数据。
使用Java和XPath在XML文档中精准定位数据
|
4月前
|
XML 前端开发 数据格式
BeautifulSoup 是一个 Python 库,用于从 HTML 和 XML 文件中提取数据
【5月更文挑战第10天】BeautifulSoup 是 Python 的一个库,用于解析 HTML 和 XML 文件,即使在格式不规范的情况下也能有效工作。通过创建 BeautifulSoup 对象并使用方法如 find_all 和 get,可以方便地提取和查找文档中的信息。以下是一段示例代码,展示如何安装库、解析 HTML 数据以及打印段落、链接和特定类名的元素。BeautifulSoup 还支持更复杂的查询和文档修改功能。
74 1
|
1月前
|
存储 C# 数据库
解决C#对Firebase数据序列化失败的难题
在游戏开发中,Unity结合Firebase实时数据库为开发者提供强大支持,但在C#中进行数据序列化和反序列化时常遇难题。文章剖析了数据丢失或反序列化失败的原因,并给出解决方案,包括使用`JsonUtility`、确保字段标记为`[Serializable]`以及正确配置网络请求。示例代码演示了如何在Unity环境中实现Firebase数据的序列化和反序列化,并通过设置代理IP、Cookies和User-Agent来增强网络请求的安全性。这些技巧有助于确保数据完整传输,提升开发效率。
解决C#对Firebase数据序列化失败的难题
|
1月前
|
XML JSON Java
使用IDEA+Maven搭建整合一个Struts2+Spring4+Hibernate4项目,混合使用传统Xml与@注解,返回JSP视图或JSON数据,快来给你的SSH老项目翻新一下吧
本文介绍了如何使用IntelliJ IDEA和Maven搭建一个整合了Struts2、Spring4、Hibernate4的J2EE项目,并配置了项目目录结构、web.xml、welcome.jsp以及多个JSP页面,用于刷新和学习传统的SSH框架。
30 0
使用IDEA+Maven搭建整合一个Struts2+Spring4+Hibernate4项目,混合使用传统Xml与@注解,返回JSP视图或JSON数据,快来给你的SSH老项目翻新一下吧
|
1月前
|
存储 安全 Java
揭秘Java序列化神器Serializable:一键解锁对象穿越时空的超能力,你的数据旅行不再受限,震撼登场!
【8月更文挑战第4天】Serializable是Java中的魔术钥匙,开启对象穿越时空的能力。作为序列化的核心,它让复杂对象的复制与传输变得简单。通过实现此接口,对象能被序列化成字节流,实现本地存储或网络传输,再通过反序列化恢复原状。尽管使用方便,但序列化过程耗时且存在安全风险,需谨慎使用。
34 7
|
30天前
|
JSON 缓存 安全
Python pickle 二进制序列化和反序列化 - 数据持久化
Python pickle 二进制序列化和反序列化 - 数据持久化
39 0
|
1月前
|
Java
JDK序列化原理问题之在JDK序列化中不同JDK版本字段不一致的情况如何解决
JDK序列化原理问题之在JDK序列化中不同JDK版本字段不一致的情况如何解决
|
3月前
|
NoSQL Redis
redis使用jackson序列化数据配置文件
redis使用jackson序列化数据配置文件
|
3月前
|
存储 分布式计算 算法