如何解析String类型的xml文件

阅读: 评论:0

如何解析String类型的xml文件

如何解析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 = RootElement();List<LineInfo> list = new ArrayList<LineInfo>();for(Iterator i = root.elementIterator(); i.hasNext();){Element lists = (Element) i.next();Name().equals("lists")) {Iterator iter = lists.elementIterator("item");while(iter.hasNext()){LineInfo line = new LineInfo();Element a = (Element) ();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;}
 

 

本文发布于:2024-01-30 23:56:44,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170663020723763.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:类型   文件   String   xml
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23