首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > XML SOAP >

怎么解析String类型的xml文件

2012-12-25 
如何解析String类型的xml文件最近做项目的时候需要解析从WebService接口返回的xml文件,xml已经转化成了Str

如何解析String类型的xml文件

最近做项目的时候需要解析从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>

那么获得的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>&nbsp;</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>&nbsp;</p>]]></detail></root>";Document dom = DocumentHelper.parseText(xml);       //获取根节点rootElement 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;}              
?

?

热点排行