XML解析与Map、Json转换,Dom4j-工具类
Stream官网下载地址:http://xstream.codehaus.org/download.html
Dom4j官网地址:http://www.dom4j.org/download.html
另外,XStream和Dom4j的详细区别,可以阅读下: http://blog.csdn.net/thunder09/article/details/5555946
1、使用Dom4j解析XMLdom4j是一个Java的XML API,类似于jdom,用来读写XML文件的。dom4j是一个非常非常优秀的JavaXML API,具有性能优异、功能强大和极端易用使用的特点,同时它也是一个开放源代码的软件,可以在SourceForge上找到它.
对主流的Java XML API进行的性能、功能和易用性的评测,dom4j无论在那个方面都是非常出色的。如今你可以看到越来越多的Java软件都在使用dom4j来读写XML,例如hibernate,包括sun公司自己的JAXM也用了Dom4j。
使用Dom4j开发,需下载dom4j相应的jar文件
dom4j-1.6.1.jar
junit-4.10.jar
一、DOM4j中,获得Document对象的方式有三种:
-
1.读取XML文件,获得document对象
-
SAXReader reader = new SAXReader();
-
Document document = reader.read(new File("csdn.xml"));
-
2.解析XML形式的文本,得到document对象.
-
String text = "<csdn></csdn>";
-
Document document = DocumentHelper.parseText(text);
-
3.主动创建document对象.
-
Document document = DocumentHelper.createDocument(); //创建根节点
-
Element root = document.addElement("csdn");
示例
(1)xml文件内容如下
- <?xml version="1.0" encoding="UTF-8"?>
- <students>
- <student1 id="001">
- <微信公众号>@残缺的孤独</微信公众号>
- <学号>20140101</学号>
- <地址>北京海淀区</地址>
- <座右铭>要么强大,要么听话</座右铭>
- </student1>
- <student2 id="002">
- <新浪微博>@残缺的孤独</新浪微博>
- <学号>20140102</学号>
- <地址>北京朝阳区</地址>
- <座右铭>在哭泣中学会坚强</座右铭>
- </student2>
- </students>
- package cn.com.yy.dom4j;
- import java.io.File;
- import java.util.Iterator;
- import java.util.List;
- import org.dom4j.Attribute;
- import org.dom4j.Document;
- import org.dom4j.Element;
- import org.dom4j.io.SAXReader;
- import org.junit.Test;
- public class Dom4JforXML {
- @Test
- public void test() throws Exception{
- //创建SAXReader对象
- SAXReader reader = new SAXReader();
- //读取文件 转换成Document
- Document document = reader.read(new File("src/cn/com/yy/dom4j/s.xml"));
- //获取根节点元素对象
- Element root = document.getRootElement();
- //遍历
- listNodes(root);
- }
- //遍历当前节点下的所有节点
- public void listNodes(Element node){
- System.out.println("当前节点的名称:" + node.getName());
- //首先获取当前节点的所有属性节点
- List<Attribute> list = node.attributes();
- //遍历属性节点
- for(Attribute attribute : list){
- System.out.println("属性"+attribute.getName() +":" + attribute.getValue());
- }
- //如果当前节点内容不为空,则输出
- if(!(node.getTextTrim().equals(""))){
- System.out.println( node.getName() + ":" + node.getText());
- }
- //同时迭代当前节点下面的所有子节点
- //使用递归
- Iterator<Element> iterator = node.elementIterator();
- while(iterator.hasNext()){
- Element e = iterator.next();
- listNodes(e);
- }
- }
- }
- 当前节点的名称:students
- 当前节点的名称:student1
- 属性id:001
- 当前节点的名称:微信公众号
- 微信公众号:@残缺的孤独
- 当前节点的名称:学号
- 学号:20140101
- 当前节点的名称:地址
- 地址:北京海淀区
- 当前节点的名称:座右铭
- 座右铭:要么强大,要么听话
- 当前节点的名称:student2
- 属性id:002
- 当前节点的名称:新浪微博
- 新浪微博:@残缺的孤独
- 当前节点的名称:学号
- 学号:20140102
- 当前节点的名称:地址
- 地址:北京朝阳区
- 当前节点的名称:座右铭
- 座右铭:在哭泣中学会坚强
- 1.获取文档的根节点.
- Element root = document.getRootElement();
- 2.取得某个节点的子节点.
- Element element=node.element(“四大名著");
- 3.取得节点的文字
- String text=node.getText();
- 4.取得某节点下所有名为“csdn”的子节点,并进行遍历.
- List nodes = rootElm.elements("csdn");
- for (Iterator it = nodes.iterator(); it.hasNext();) {
- Element elm = (Element) it.next();
- // do something
- }
- 5.对某节点下的所有子节点进行遍历.
- for(Iterator it=root.elementIterator();it.hasNext();){
- Element element = (Element) it.next();
- // do something
- }
- 6.在某节点下添加子节点
- Element elm = newElm.addElement("朝代");
- 7.设置节点文字. elm.setText("明朝");
- 8.删除某节点. parentElement.remove(childElment); //childElement是待删除的节点,parentElement是其父节点
- 9.添加一个CDATA节点. Element contentElm = infoElm.addElement("content"); contentElm.addCDATA(“cdata区域”);
(5)节点对象的属性方法操作
- 1.取得某节点下的某属性 Element root=document.getRootElement(); //属性名name
- Attribute attribute=root.attribute("id");
- 2.取得属性的文字
- String text=attribute.getText();
- 3.删除某属性 Attribute attribute=root.attribute("size"); root.remove(attribute);
- 4.遍历某节点的所有属性
- Element root=document.getRootElement();
- for(Iterator it=root.attributeIterator();it.hasNext();){
- Attribute attribute = (Attribute) it.next();
- String text=attribute.getText();
- System.out.println(text);
- }
- 5.设置某节点的属性和文字. newMemberElm.addAttribute("name", "sitinspring");
- 6.设置属性的文字 Attribute attribute=root.attribute("name"); attribute.setText("csdn");
/**
*XML解析与Map、Json、Bean转换
*/
public class XmlConverUtil {
// map to xml
public static String maptoXml(Map map) {
Document document = DocumentHelper.createDocument();
Element nodeElement = document.addElement("node");
for (Object obj : map.keySet()) {
Element keyElement = nodeElement.addElement("key");
keyElement.addAttribute("label", String.valueOf(obj));
keyElement.setText(String.valueOf(map.get(obj)));
}
return doc2String(document);
}
// list to xml
public static String listtoXml(List list) throws Exception {
Document document = DocumentHelper.createDocument();
Element nodesElement = document.addElement("nodes");
int i = 0;
for (Object o : list) {
Element nodeElement = nodesElement.addElement("node");
if (o instanceof Map) {
for (Object obj : ((Map) o).keySet()) {
Element keyElement = nodeElement.addElement("key");
keyElement.addAttribute("label", String.valueOf(obj));
keyElement.setText(String.valueOf(((Map) o).get(obj)));
}
} else {
Element keyElement = nodeElement.addElement("key");
keyElement.addAttribute("label", String.valueOf(i));
keyElement.setText(String.valueOf(o));
}
i++;
}
return doc2String(document);
}
// json to xml
public static String jsontoXml(String json) {
try {
XMLSerializer serializer = new XMLSerializer();
JSON jsonObject = JSONSerializer.toJSON(json);
return serializer.write(jsonObject);
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
// xml to map
public static Map xmltoMap(String xml) {
try {
Map map = new HashMap();
Document document = DocumentHelper.parseText(xml);
Element nodeElement = document.getRootElement();
List node = nodeElement.elements();
for (Iterator it = node.iterator(); it.hasNext();) {
Element elm = (Element) it.next();
map.put(elm.attributeValue("label"), elm.getText());
elm = null;
}
node = null;
nodeElement = null;
document = null;
return map;
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
//xml to list
public static List xmltoList(String xml) {
try {
List<Map> list = new ArrayList<Map>();
Document document = DocumentHelper.parseText(xml);
Element nodesElement = document.getRootElement();
List nodes = nodesElement.elements();
for (Iterator its = nodes.iterator(); its.hasNext();) {
Element nodeElement = (Element) its.next();
Map map = xmltoMap(nodeElement.asXML());
list.add(map);
map = null;
}
nodes = null;
nodesElement = null;
document = null;
return list;
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
// xml to json
public static String xmltoJson(String xml) {
XMLSerializer xmlSerializer = new XMLSerializer();
return xmlSerializer.read(xml).toString();
}
// Document to xml
public static String doc2String(Document document) {
String s = "";
try {
//
ByteArrayOutputStream out = new ByteArrayOutputStream();
//
OutputFormat format = new OutputFormat(" ", true, "UTF-8");
XMLWriter writer = new XMLWriter(out, format);
writer.write(document);
s = out.toString("UTF-8");
out.close();
} catch (Exception ex) {
ex.printStackTrace();
}
return s;
}
public static void main(String[] args){
Map map=new HashMap();
map.put("aa", "aa0001");
map.put("bb", "bb0002");
String msg=XmlConverUtil.maptoXml(map);
System.out.println(msg);
}
}
更多推荐
所有评论(0)