由于项目特殊,需要解析的xml文档样式特别,所以自己写了一个解析特殊xml的方法

先提供xml样式

<?xml version="1.0" encoding="UTF-8"?>
<root>
<head>
<head1>1</head1>
<head2>2</head2>
<head3>3</head3>
<head4>4</head4>
<head5>5</head5>
<head6>6</head6>
<head7>7</head7>
<head8>8</head8>
<head9>9</head9>
<head10>10</head10>
<head11>11</head11>
</head>
<body>
<body1>1</body1>
<body2>2</body2>
<body3>3</body3>
<body4>4</body4>
<body5>5</body5>
<body6>6</body6>
<body7>7</body7>
<details>
<detail>
<gradeitem>A</gradeitem>
<gradevalue>1</gradevalue>
</detail>
<detail>
<gradeitem>B</gradeitem>
<gradevalue>2</gradevalue>
</detail>
<detail>
<gradeitem>C</gradeitem>
<gradevalue>3</gradevalue>
</detail>
<detail>
<gradeitem>D</gradeitem>
<gradevalue>4</gradevalue>
</detail>
<detail>
<gradeitem>E</gradeitem>
<gradevalue>5</gradevalue>
</detail>
<detail>
<gradeitem>F</gradeitem>
<gradevalue>6</gradevalue>
</detail>
<detail>
<gradeitem>G</gradeitem>
<gradevalue>7</gradevalue>
</detail>
<detail>
<gradeitem>H</gradeitem>
<gradevalue>8</gradevalue>
</detail>
<detail>
<gradeitem>I</gradeitem>
<gradevalue>9</gradevalue>
</detail>
</details>
</body>
</root>

看到这个xml大家就知道哪里特殊了吧,首先head部分正常,标签名作为map的key,内容作为value;但是body中有一部分是这个规则,但另一部分是details包着的detail标签,这个<gradeitem>H</gradeitem>标签里包的值是map的key,这个<gradevalue>9</gradevalue>标签里的值是map的value;

public static Map<String, String> xmlToMap(String data) {
Map<String, String> map = new HashMap<String, String>();
ParseRatingData prd = new ParseRatingData();
Document doc;
try {
doc = DocumentHelper.parseText(data);
Element root = doc.getRootElement();
} catch (DocumentException e) {
e.printStackTrace();
}
return map;
}

先获取根节点是必须的了,首先我想的是把details标签内的东西解析掉,然后剩下的是一个规则,也就是要有两种方式去解析该xml

public static Map<String, String> xmlToMap(String data) {
Map<String, String> map = new HashMap<String, String>();
ParseRatingData prd = new ParseRatingData();
Document doc;
try {
doc = DocumentHelper.parseText(data);
Element root = doc.getRootElement();
// 解析head
Element head = root.element("head");
map.putAll(prd.nodeToMap(head,"head",map));
// 解析body
Element body = root.element("body");
map.putAll(prd.nodeToMap(body,"body",map));
// 解析details
Element details = body.element("details");
List<Element> detailList = details.elements("detail");
for (Element detail : detailList) {
map.put(detail.elementText("gradeitem"), detail.elementText("gradevalue"));
}
} catch (DocumentException e) {
e.printStackTrace();
}
return map;
}

这是刚才那个方法的全部代码,解析details部分就是先获取到details下的所有detail,放在一个list集合中,然后分别取得不同标签下的value值作为map的key和value

细心的同学已经发现nodeToMap(Element ele,String str,Map map)这个方法了吧,下面看看这个方法都写了啥

public Map<String, String> nodeToMap(Element node,String str,Map<String, String> map){
if(!str.equals(node.getName())){
if("details".equals(node.getName())){
return map;
}
map.put(node.getName(), node.getTextTrim());//当前节点名称,当前节点内容
}
//递归遍历当前节点所有的子节点
List<Element> listElement=node.elements();//所有一级子节点的list
for(Element e:listElement){//遍历所有一级子节点
nodeToMap(e,"",map);//递归
}
return map;
}

这个就是另外一种普通的解析方式,利用递归的方式遍历传入的node参数下的所有的子节点,然后将该节点的标签名作为map的key,值作为map的value

需要注意的一点就是为了方便,我将参数中加的str实际就是传入node参数的String格式,如果相同,则为父节点,不往map中放,不同的时候表示为子节点才会放在map中

如果出现details节点,说明body遍历到这儿就拉倒了,接下来是details遍历需要处理的东西,直接return出去就好,这里传入map参数是为了直接在原来的map的基础上直接添加数据。

解析完毕,大神们有什么意见看法请不吝赐教啊~

欢迎转载,转载请注明出处

Java从入门到放弃,MySQL从删库到跑路~~~

解析特殊格式的xml到map的更多相关文章

  1. XML系列之--解析电文格式的XML(二)

    上一节介绍了XML的结构以及如何创建.讲到了XML可作为一种简单文本存储数据,把数据存储起来,以XML的方式进行传递.当接收到XML时,必不可少的就是对其进行解析,捞取有效数据,或者将第三方数据以节点 ...

  2. Linq解析带命名空间、前缀、Soap格式的XML

    关于XML,经常会用到,XML有一般的,同样也有二般的,更不要觉得会操作基础的XML就觉得自己已经精通XML操作,文中是对解析XML的方法进行介绍 1. 一般XML <?xml version= ...

  3. Linq创建带命名空间、前缀、Soap格式的XML

    关于XML,我也是刚接触,关于一般常见的XML,博客园.CSDN上的资料很多,对于不常见的带命名空间.前缀.Soap格式的XML的描述相对来说寥寥无几,上一篇我写到了对相对复杂的XML的读操作,下面说 ...

  4. XML系列之--创建电文格式的XML(一)

    关于XML,学校那会,老师在口中仅仅提及,自己也未曾深入接触过,仅是些将最基本XML文件内容显示在web定义的表格中之类的简单操作,如今项目中的收发电文涉及到复杂XML的操作.趁此契机好好回顾下XML ...

  5. XML解析与xml和Map集合的互转

    1.XML的解析.首先解析XML文件我们需要先获取到文件的存放路径,获取方法有三种分别获取xml文件不同的存放路径. 代码: public class PropertiesDemo { public ...

  6. 【dom4j】解析xml为map

    dom4j解析xml文件 <?xml version="1.0" encoding="utf-8"?> <workflows> < ...

  7. 解析xml报文,xml与map互转

    这段时间写了一个关于xml报文的工具类,做一下具体的讲解: xml文本 <NTMMessage version="1.03"> <NTMHeader> &l ...

  8. Java xml和map,list格式的转换-摘抄

    import java.io.ByteArrayOutputStream; import java.util.ArrayList; import java.util.HashMap; import j ...

  9. XML转换为Map通用算法实现 Java版本(Stax实现)

    目前项目中需要将XML转换为Map,下面给出了自己的代码实现. 后续将为大家提供Dom版本的实现. 请各路大神给予各种优良实现. 场景: 在项目中需要解析XML文本字符串,需要将XML文本字符串映射为 ...

随机推荐

  1. android-----JNI中的log打印【转】

    本文转载自:http://blog.csdn.net/zengraoli/article/details/11644815 1. 导入log头文件 在你使用的 .c/ .cpp 文件中 导入 log. ...

  2. Generic Interfaces (C# Programming Guide)

    https://msdn.microsoft.com/en-us/library/kwtft8ak(v=vs.140).aspx It is often useful to define interf ...

  3. influx测试——单条读性能很差,大约400条/s,批量写性能很高,7万条/s,总体说来适合IOT数据批量存,根据tag查和过滤场景,按照时间顺序返回

    测试准备 需要将InfluxDB的源码放入 go/src/github.com/influxdata 目录 单写测试代码(write1.go): package main import ( " ...

  4. 【线程安全】—— 单例类双重检查加锁(double-checked locking)

    1. 三个版本单例类的实现 版本1:经典版 public class Singleton { public static Singleton getInstance() { if (instance ...

  5. Java开源JSP标签库

    01displytag 与Struts结合使用最出名的一个tag主要是显示表格数据很漂亮.完善. 02cewolf tag 用来在web上显示复杂图形报表的一个jsp tag. 03Loading T ...

  6. vue实现全选,反选

    1.example.vue <template> <table class="table-common"> <tr> <th class= ...

  7. 使用 typescript 开发 Vue

    基础配置: 1. 准备一个使用 vue-cli 生成的项目 2. 使用 npm 一建安装基础配置 npm i -S @types/node typescript vue-class-component ...

  8. knockjs

    用VS2012建立Web站点有个新惊喜,默认加了KnockoutJS这个Javascript的MVVM模式的实现库,方便Web前端的开发 官方站点 √主页:  http://www.knockoutj ...

  9. Windows键盘驱动结构与消息机制--转

    https://www.douban.com/note/318793892/ 本文主要介绍按键消息是如何传递到窗口并转化为具体的按键消息的. Windows系统是事件驱动的多任务系统,其中按键和鼠标是 ...

  10. OpenCV绘制检测结果

    OpenCV绘制检测结果 opencv  rtcp  timestamp  一.介绍 由于在验证阶段,使用FPGA时我们的算法检测速度很慢,没法直接在主流上进行绘图,否则的话,主流就要等待算法很久才能 ...