【Groovy】xml 序列化 ( 使用 MarkupBuilder 生成 xml 数据 | 标签闭包下创建子标签 | 使用 MarkupBuilderHelper 添加 xml 注释 )

简介: 【Groovy】xml 序列化 ( 使用 MarkupBuilder 生成 xml 数据 | 标签闭包下创建子标签 | 使用 MarkupBuilderHelper 添加 xml 注释 )

一、标签闭包下创建子标签


在上一篇博客 【Groovy】xml 序列化 ( 使用 MarkupBuilder 生成 xml 数据 ) 生成的 xml 文件基础上 , 如果要在标签下 , 创建子标签 , 如下的  标签下再创建  标签 ;


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


在创建标签的闭包中 , 再次嵌套创建标签即可 ;


markupBuilder.student{
    // 标签下创建子标签
    team() {
        member("Jerry") {}
    }
}


完整代码如下 :


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

二、使用 MarkupBuilderHelper 添加 xml 注释


在闭包中可以通过 mkp 获取 MarkupBuilderHelper 对象 , 该对象可以帮助添加 xml 注释 ;



 

/**
     * 属性,该属性可以从生成器闭包中调用以访问帮助器方法,
     * 即 {@link MarkupBuilderHelper#yield(String)},
     * {@link MarkupBuilderHelper#yieldUnescaped(String)},
     * {@link MarkupBuilderHelper#pi(Map)},
     * {@link MarkupBuilderHelper#xmlDeclaration(Map)} and
     * {@link MarkupBuilderHelper#comment(String)}.
     *
     * @return this MarkupBuilder
     */
    public MarkupBuilderHelper getMkp() {
        return new MarkupBuilderHelper(this);
    }


MarkupBuilderHelper 类中提供了一些方法 , 其中 comment 方法 , 可以用于添加注释 ;


public class MarkupBuilderHelper {
    private final MarkupBuilder builder;
    /**
     * 在输出中生成注释。
     * <p>
     * <code>mkp.comment 'string'</code> is equivalent to
     * <code>mkp.yieldUnescaped '&lt;!-- string --&gt;'</code>.
     * To create an element with the name 'comment', you need
     * to supply empty attributes, e.g.:
     * <pre>
     * comment('hello1')
     * </pre>
     * or
     * <pre>
     * mkp.comment('hello1')
     * </pre>
     * will produce:
     * <pre>
     * &lt;!-- hello1 --&gt;
     * </pre>
     * while:
     * <pre>
     * comment('hello2', [:])
     * </pre>
     * will produce:
     * <pre>
     * &lt;comment&gt;hello2&lt;/comment&gt;
     * </pre>
     *
     * @param value the text within the comment.
     */
    public void comment(String value) {
        yieldUnescaped("<!-- " + value + " -->");
    }
}


在闭包中使用 mkp.comment("学生姓名") 代码 , 可以生成  注释 ;


markupBuilder.student{
    mkp.comment("学生姓名")
}

三、完整代码示例


完整代码示例 :


import groovy.xml.MarkupBuilder
"""
<student>
    <name code="utf-8">Tom</name>
    <age>18</age>
    <team>
        <member>Jerry</member>
    </team>
</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") {
    }
    mkp.comment("学生姓名")
    age(18) {}
    mkp.comment("学生年龄")
    // 标签下创建子标签
    team() {
        member("Jerry") {}
    }
    mkp.comment("小组成员")
}


执行结果 :


<student>
  <name code='utf-8'>Tom</name><!-- 学生姓名 -->
  <age>18</age><!-- 学生年龄 -->
  <team>
    <member>Jerry</member>
  </team><!-- 小组成员 -->
</student>


image.png

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
|
7月前
|
XML 前端开发 数据格式
BeautifulSoup 是一个 Python 库,用于从 HTML 和 XML 文件中提取数据
【5月更文挑战第10天】BeautifulSoup 是 Python 的一个库,用于解析 HTML 和 XML 文件,即使在格式不规范的情况下也能有效工作。通过创建 BeautifulSoup 对象并使用方法如 find_all 和 get,可以方便地提取和查找文档中的信息。以下是一段示例代码,展示如何安装库、解析 HTML 数据以及打印段落、链接和特定类名的元素。BeautifulSoup 还支持更复杂的查询和文档修改功能。
139 1
|
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月前
|
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框架。
113 0
使用IDEA+Maven搭建整合一个Struts2+Spring4+Hibernate4项目,混合使用传统Xml与@注解,返回JSP视图或JSON数据,快来给你的SSH老项目翻新一下吧
|
4月前
|
SQL Java 数据库连接
MyBatis Mapper.XML 标签使用说明
MyBatis Mapper.XML 标签使用说明
45 0
|
6月前
|
XML 存储 JavaScript
50. 【Android教程】xml 数据解析
50. 【Android教程】xml 数据解析
73 1