当前位置: 首页 > article >正文

dom4j实现xml转map,xml转json字符串

 dom4j依赖包

        <!--dom4j-->
        <dependency>
            <groupId>dom4j</groupId>
            <artifactId>dom4j</artifactId>
            <version>1.6.1</version>
        </dependency>

map转为json字符串方法很多,这里使用fastjson

        <!--fastjson 版本1.2.78是Fastjson在发布时的最后一个支持Java 1.7的版本-->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>1.2.78</version>
        </dependency>

dom4j实现xml转map,再使用 fastjson 将map转为json字符串

package com.study;

import com.alibaba.fastjson.JSON;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;

import java.util.ArrayList;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;

public class Test {
    public static void main(String[] args) throws Exception {
        String xml = "<sites><site><name>RUNOOB</name><url>www.runoob.com</url></site><site><name>Google</name><url>www.google.com</url></site><site><name>Facebook</name><url>www.facebook.com</url></site></sites>";
        Map<String, Object> map = xml2map(xml);
        String json = JSON.toJSONString(map);
        System.out.println(json);
    }

    /**
     * xml转map 不带属性
     */
    public static Map<String, Object> xml2map(String xml) throws DocumentException {
        // xml必须有一个根节点
        xml = "<root>" + xml + "</root>";
        Document document = DocumentHelper.parseText(xml);
        Element root = document.getRootElement(); //根节点
        Map<String, Object> map = xml2map(root);
        return map;
    }

    /**
     * xml转map 不带属性
     * 如果是兄弟元素,并且兄弟元素的标签相同,那么这些相同名称的兄弟需要合并为一个数组
     */
    private static Map<String, Object> xml2map(Element element) {
        Map<String, Object> map = new LinkedHashMap<>();
        List<Element> list = element.elements(); //获取所有子节点
        if (list.size() > 0) { //有子节点
            for (Element iter : list) { //遍历所有子节点
                List<Object> mapList;
                if (iter.elements().size() > 0) { //子节点还有子节点
                    Map<String, Object> m = xml2map(iter); //递归调用
                    if (map.get(iter.getName()) != null) { //标签名称已经存在,说明是一个数组结构
                        Object obj = map.get(iter.getName());
                        if (obj instanceof List) { //标签的值是数组结构,取出数组添加新的元素
                            mapList = (List) obj; //取出旧值
                            mapList.add(m); //放入新值
                        } else {
                            mapList = new ArrayList<>();
                            mapList.add(obj); //放入旧值
                            mapList.add(m); //放入新值
                        }
                        map.put(iter.getName(), mapList);
                    } else {
                        map.put(iter.getName(), m);
                    }
                } else { //子节点无子节点
                    if (map.get(iter.getName()) != null) { //标签名称已经存在,说明是一个数组结构
                        Object obj = map.get(iter.getName());
                        if (obj instanceof List) { //标签的值是数组结构,取出数组添加新的元素
                            mapList = (List) obj; //取出旧值
                            mapList.add(iter.getText()); //放入新值
                        } else {
                            mapList = new ArrayList<>();
                            mapList.add(obj); //放入旧值
                            mapList.add(iter.getText()); //放入新值
                        }
                        map.put(iter.getName(), mapList);
                    } else {
                        map.put(iter.getName(), iter.getText());
                    }
                }
            }
        }
        return map;
    }

}

效果如下:

<sites>
    <site>
        <name>RUNOOB</name>
        <url>www.runoob.com</url>
    </site>
    <site>
        <name>Google</name>
        <url>www.google.com</url>
    </site>
    <site>
        <name>Facebook</name>
        <url>www.facebook.com</url>
    </site>
</sites>

xml转换为json后效果

{
	"sites": {
		"site": [
			{
				"name": "RUNOOB",
				"url": "www.runoob.com"
			},
			{
				"name": "Google",
				"url": "www.google.com"
			},
			{
				"name": "Facebook",
				"url": "www.facebook.com"
			}
		]
	}
}


http://www.kler.cn/a/388134.html

相关文章:

  • 软件工程概论项目(二),node.js的配置,npm的使用与vue的安装
  • 学术论文写作丨机器学习与深度学习
  • 如何从头开始构建神经网络?(附教程)
  • openSUSE 环境下通过 zypper 安装软件
  • 【蓝桥等考C++真题】蓝桥杯等级考试C++组第13级L13真题原题(含答案)-最大的数
  • uniapp 设置安全区域
  • 【IEEE/EI会议/南邮主办】第六届机器人、智能控制与人工智能国际学术会议(RICAI 2024)
  • Oracle 第25章:Oracle GoldenGate
  • 斗破QT编程入门系列之前言:认识Qt:获取与安装(四星斗师)
  • 13-鸿蒙开发中的综合实战:华为登录界面
  • 机器学习系列----介绍前馈神经网络和卷积神经网络 (CNN)
  • GooglePlay: 应用和游戏的内容分级
  • 机器学习—选择激活函数
  • json绘制热力图
  • 大数据面试题--kafka夺命连环问
  • Unity——对RectTransform进行操作
  • gitlab无法创建合并请求是所有分支都不显示
  • 从特殊角度解释深度学习,一节课让你彻底明白深度学习的“前世今生”!
  • MySQL 和 PostgreSQL 的使用案例
  • docker中widows安装mysql
  • vuepress配置谷歌广告-通过vue-google-adsense库
  • 外包干了5年,技术退步太明显了。。。。。
  • MongoDB——服务端连接及查询
  • 【2048】我的创作纪念日
  • 保研考研机试攻略:python笔记(3)
  • Flutter鸿蒙next 实现长按录音按钮及动画特效