由于项目特殊,需要解析的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. oc81--copy内存管理

    // // main.m // Copy内存管理(MRC才有内存管理) // #import <Foundation/Foundation.h> int main(int argc, co ...

  2. 一些SQL高级函数

    一些SQL高级函数 Posted on 2010-08-08 21:34 moss_tan_jun 阅读(311) 评论(0) 编辑 收藏 长度与分析用 datalength(Char_expr) 返 ...

  3. Linux系统下vim常用快捷键及功能

    1. 什么是vim Vim是一个类似于Vi的著名的功能强大.高度可定制的文本编辑器,在vi的基础上改进和增加了很多特性. vim编辑器是Linux系统下标准的编辑器,作用相当于windows系统中的记 ...

  4. POJ3070Fibonacci

    矩阵乘法裸题 求快速幂 #include<iostream> #include<cstdio> #define ll long long #define Mod 10000 u ...

  5. akka设计模式系列-基础模式

    本文介绍akka的基本使用方法,由于属于基础功能,想不出一个很高大上的名称,此处就以基础模式命名.下文会介绍actor的使用方法,及其优劣点. class SimpleActor(name:Strin ...

  6. 记一次MySQL索引优化

    两张表是主(CHECK_DRAWINGS)从(CHECK_DRAWINGS_IMG)关系. CHECK_DRAWINGS,主表数据 3591条. SELECT COUNT(*) FROM CHECK_ ...

  7. hdu---3177 Crixalis's Equipment 根据 两个元素 之间的权衡进行排序

    Crixalis's Equipment Problem Description Crixalis - Sand King used to be a giant scorpion(蝎子) in the ...

  8. 题解报告:hdu 1564 Play a game(找规律博弈)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1564 Problem Description New Year is Coming! ailyanlu ...

  9. 326 Power of Three 3的幂

    给出一个整数,写一个函数来确定这个数是不是3的一个幂.后续挑战:你能不使用循环或者递归完成本题吗? 详见:https://leetcode.com/problems/power-of-three/de ...

  10. [转]Linux命令wc的详细用法

    转自:http://blog.hehehehehe.cn/a/17301.htm wc命令用来打印文件的文本行数.单词数.字节数等(print the number of newlines, word ...