如何解析String类型的XML
来源:互联网 发布:销售单打印软件免费版 编辑:程序博客网 时间:2024/04/30 10:31
最近做项目的时候需要解析从WebService接口返回的xml文件,xml已经转化成了String类型,解析之后保存在一个List中。
比如,其中有个xml文件为:
- <?xml version="1.0" encoding="UTF-8">
- <root>
- <lists>
- <item>
- <id><![CDATA[202]]]]>><![CDATA[</id>
- <travel><![CDATA[ 南京一日游专业委员会]]]]>><![CDATA[</travel>
- <cost><![CDATA[200元/人]]]]>><![CDATA[</cost>
- <tel><![CDATA[4008859110]]]]>><![CDATA[</tel>
- <imgurl><![CDATA[]]]]>><![CDATA[</imgurl>
- <name><![CDATA[南京一日游]]]]>><![CDATA[</name>
- </item>
- <item>
- <id><![CDATA[203]]]]>><![CDATA[</id>
- <travel><![CDATA[ 南京一日游专业委员会]]]]>><![CDATA[</travel>
- <cost><![CDATA[420元/人]]]]>><![CDATA[</cost>
- <tel><![CDATA[4008859110]]]]>><![CDATA[</tel>
- <imgurl><![CDATA[]]]]>><![CDATA[</imgurl>
- <name><![CDATA[南京二日游]]]]>><![CDATA[</name>
- </item>
- <item>
- <id><![CDATA[249]]]]>><![CDATA[</id>
- <travel><![CDATA[ 南京春苗旅行社有限责任公司]]]]>><![CDATA[</travel>
- <cost><![CDATA[成人68元/人 儿童60元/人]]]]>><![CDATA[</cost>
- <tel><![CDATA[025-57010679]]]]>><![CDATA[</tel>
- <imgurl><![CDATA[]]]]>><![CDATA[</imgurl>
- <name><![CDATA[六合竹镇森林公园、大泉湖、农家乐、火山石柱林]]]]>><![CDATA[</name>
- </item>
- </lists>
- </root>
<?xml version="1.0" encoding="UTF-8"><root><lists> <item> <id><![CDATA[202]]]]>><![CDATA[</id><travel><![CDATA[ 南京一日游专业委员会]]]]>><![CDATA[</travel><cost><![CDATA[200元/人]]]]>><![CDATA[</cost><tel><![CDATA[4008859110]]]]>><![CDATA[</tel><imgurl><![CDATA[]]]]>><![CDATA[</imgurl><name><![CDATA[南京一日游]]]]>><![CDATA[</name> </item> <item> <id><![CDATA[203]]]]>><![CDATA[</id><travel><![CDATA[ 南京一日游专业委员会]]]]>><![CDATA[</travel><cost><![CDATA[420元/人]]]]>><![CDATA[</cost><tel><![CDATA[4008859110]]]]>><![CDATA[</tel><imgurl><![CDATA[]]]]>><![CDATA[</imgurl><name><![CDATA[南京二日游]]]]>><![CDATA[</name> </item> <item> <id><![CDATA[249]]]]>><![CDATA[</id><travel><![CDATA[ 南京春苗旅行社有限责任公司]]]]>><![CDATA[</travel><cost><![CDATA[成人68元/人 儿童60元/人]]]]>><![CDATA[</cost><tel><![CDATA[025-57010679]]]]>><![CDATA[</tel><imgurl><![CDATA[]]]]>><![CDATA[</imgurl><name><![CDATA[六合竹镇森林公园、大泉湖、农家乐、火山石柱林]]]]>><![CDATA[</name> </item> </lists></root>
那么获得的String类型的xml就是:
- String xml = "<?xml version='1.0' encoding='UTF-8'?><root><name><![CDATA[常州恐龙园一日(一票制无自理)]]></name><cost><![CDATA[178元/成人]]></cost><tel><![CDATA[028-83196681]]></tel><travel><![CDATA[ 中青旅江苏国际旅行社有限公司]]></travel><detail><![CDATA[<span style='font-family:楷体_GB2312;font-size:9pt;'>常州现代旅游休闲区启动开发的一期工程,中华恐龙馆总面积<span>14000</span>平方米,穹顶最高处<span>36</span>米,龙首最高处达<span>71</span>米,以其宏大的空间和别具一格的建筑语言,成为常州旅游的标志性建筑。</span><p> </p>]]></detail></root>";
String xml = "<?xml version='1.0' encoding='UTF-8'?><root><name><![CDATA[常州恐龙园一日(一票制无自理)]]></name><cost><![CDATA[178元/成人]]></cost><tel><![CDATA[028-83196681]]></tel><travel><![CDATA[ 中青旅江苏国际旅行社有限公司]]></travel><detail><![CDATA[<span style='font-family:楷体_GB2312;font-size:9pt;'>常州现代旅游休闲区启动开发的一期工程,中华恐龙馆总面积<span>14000</span>平方米,穹顶最高处<span>36</span>米,龙首最高处达<span>71</span>米,以其宏大的空间和别具一格的建筑语言,成为常州旅游的标志性建筑。</span><p> </p>]]></detail></root>";
首先就是利用dom4j的DocumentHelper.parseText解析此String类型的xml,然后在遍历节点。
完整代码如下:
- import java.util.ArrayList;
- import java.util.Iterator;
- import java.util.List;
- import org.dom4j.Document;
- import org.dom4j.DocumentException;
- import org.dom4j.DocumentHelper;
- import org.dom4j.Element;
- public List<LineInfo> getLine() throws DocumentException {
- String xml = "<?xml version='1.0' encoding='UTF-8'?><root><name><![CDATA[常州恐龙园一日(一票制无自理)]]></name><cost><![CDATA[178元/成人]]></cost><tel><![CDATA[028-83196681]]></tel><travel><![CDATA[ 中青旅江苏国际旅行社有限公司]]></travel><detail><![CDATA[<span style='font-family:楷体_GB2312;font-size:9pt;'>常州现代旅游休闲区启动开发的一期工程,中华恐龙馆总面积<span>14000</span>平方米,穹顶最高处<span>36</span>米,龙首最高处达<span>71</span>米,以其宏大的空间和别具一格的建筑语言,成为常州旅游的标志性建筑。</span><p> </p>]]></detail></root>";
- Document dom = DocumentHelper.parseText(xml);
- //获取根节点root
- Element root = dom.getRootElement();
- List<LineInfo> list = new ArrayList<LineInfo>();
- for(Iterator i = root.elementIterator(); i.hasNext();){
- Element lists = (Element) i.next();
- if(lists.getName().equals("lists")) {
- Iterator iter = lists.elementIterator("item");
- while(iter.hasNext()){
- LineInfo line = new LineInfo();
- Element a = (Element) iter.next();
- String id = a.elementTextTrim("id");
- line.setId(id);
- String travel = a.elementTextTrim("travel");
- line.setTravel(travel);
- String cost = a.elementTextTrim("cost");
- line.setCost(cost);
- String tel = a.elementTextTrim("tel");
- line.setTel(tel);
- String imgurl = a.elementTextTrim("imgurl");
- line.setImgurl(imgurl);
- String name = a.elementTextTrim("name");
- line.setLineName(name);
- list.add(line);
- }
- }
- }
- return list;
- }
- 如何解析String类型的XML
- 解析String类型的XML
- java 解析String类型的xml
- Dom4j解析String类型的xml数据
- java解析string类型的xml
- DOM4J解析String类型的xml文件
- Android--<String>XX</String>类型的XML解析
- 调用接口,解析返回的的string类型xml文档
- java解析由String类型拼接的XML文件
- java string类型xml解析为对象
- 利用pull解析器解析服务器返回的String类型的XML
- String拼接的xml解析
- 在已知XML文件内容时,使用dom4j简单解析XML(String类型的XML)(用于服务器端)
- 通过递归的方式解析String 字符串类型的XML并保存进实体
- java解析String类型t复杂xml,多级节点,最好的例子
- 如何解析key为数字的string类型的Json数据
- 解析String类型的数据的方法
- 如何把一个String类型的sparql语句,解析出一系列triple
- IOS 断点续传
- php 环境 配置
- 专访邓凡平:Android开发路上的快速学习之道
- 局部图像特征描述概述
- ActionScript3.0中的Number精度问题
- 如何解析String类型的XML
- 结构体位域
- Linux flash 文件系统剖析
- iOS Programming 101: How To Hide Tab Bar in Navigation Interface
- OCX打包成CAB包以及签名发布
- 一维动量守恒
- 越狱xcode
- 多角度回弹
- delphi中多线程同步的一些方法