Java怎么把XML转换成嵌套的Map结构

畫卷琴夢
发布: 2025-12-15 18:34:42
原创
753人浏览过
Java中将XML转为嵌套Map的核心是用DOM解析器递归遍历节点,以元素名为key、文本或子Map为value,同名兄弟节点存为List,混合内容用#text键分离,忽略空白文本节点。

java怎么把xml转换成嵌套的map结构

Java中把XML转换成嵌套的Map结构,核心思路是解析XML树,递归遍历节点,将元素名作为key、文本内容或子节点Map作为value,构建出类似JSON对象的嵌套Map(如 Map<string object></string>)。推荐使用轻量、易控的DOM解析器,配合递归逻辑实现,避免引入复杂框架(如Jackson XML)带来的类型约束或配置负担。

用DOM解析器递归构建嵌套Map

DOM适合小到中等XML(内存可接受),能直观反映层级关系。关键点:区分元素节点与文本节点,处理同名兄弟节点(转为List),忽略空白文本节点。

  • DocumentBuilder 加载XML字符串或文件,获取根 Element
  • 写一个递归方法 nodeToMap(Node node),对每个元素节点:
    • 收集所有子 Element 节点,按标签名分组(同名多个 → 放入 List<map></map>
    • 若只有一个子元素且无属性、无文本、无其他子元素,可直接映射为值(简化场景)
    • 若有文本内容(getTextContent().trim()非空),且无子元素,则该元素值为字符串;否则值为子Map或Map列表
    • 属性统一放入 @attributes 子Map(可选,按需启用)

处理同名兄弟节点和混合内容

真实XML常有重复标签(如 <item></item><item></item>)或元素内含文本+子元素(混合内容)。这时不能简单用 Map<string object></string> 直接put,需判断:

  • 若某标签出现多次,其对应value应为 ArrayList<map object>></map>,而非单个Map
  • 若元素既有文本又有子元素(如 <name>John<suffix>Jr.</suffix></name>),建议将文本存为 #text key,子元素照常嵌套(类似JavaScript DOM风格)
  • 跳过 Node.TEXT_NODE 中纯空白(isAllWhitespace()),防止空格污染Map

一个精简可用的工具方法示例

以下代码片段可直接复用(已处理常见边界):

Tanka
Tanka

具备AI长期记忆的下一代团队协作沟通工具

Tanka 146
查看详情 Tanka

立即学习Java免费学习笔记(深入)”;

public static Map<String, Object> xmlToMap(String xml) throws Exception {
    Document doc = DocumentBuilderFactory.newInstance()
        .newDocumentBuilder().parse(new ByteArrayInputStream(xml.getBytes()));
    return nodeToMap(doc.getDocumentElement());
}

private static Map<String, Object> nodeToMap(Node node) {
    Map<String, Object> result = new LinkedHashMap<>();
    // 处理属性
    if (node.getAttributes() != null) {
        Map<String, String> attrs = new LinkedHashMap<>();
        for (int i = 0; i < node.getAttributes().getLength(); i++) {
            Node attr = node.getAttributes().item(i);
            attrs.put(attr.getNodeName(), attr.getNodeValue());
        }
        if (!attrs.isEmpty()) result.put("@attributes", attrs);
    }

    NodeList children = node.getChildNodes();
    Map<String, List<Map<String, Object>>> childGroups = new LinkedHashMap<>();

    for (int i = 0; i < children.getLength(); i++) {
        Node child = children.item(i);
        if (child.getNodeType() == Node.ELEMENT_NODE) {
            String name = child.getNodeName();
            childGroups.computeIfAbsent(name, k -> new ArrayList<>())
                       .add(nodeToMap(child));
        } else if (child.getNodeType() == Node.TEXT_NODE) {
            String text = child.getTextContent().trim();
            if (!text.isEmpty()) {
                result.put("#text", text);
            }
        }
    }

    // 拆分group:单个→Map,多个→List<Map>
    for (Map.Entry<String, List<Map<String, Object>>> e : childGroups.entrySet()) {
        List<Map<String, Object>> list = e.getValue();
        result.put(e.getKey(), list.size() == 1 ? list.get(0) : list);
    }

    return result;
}
登录后复制

基本上就这些。不复杂但容易忽略空白文本和同名节点合并逻辑。如果XML较大或需流式处理,可换用StAX(XMLStreamReader)手动构建Map,控制内存更精细。

以上就是Java怎么把XML转换成嵌套的Map结构的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号