java中采用Pull解析器对XML文件进行解析

来源:互联网 发布:apple mac.pro 病毒 编辑:程序博客网 时间:2024/04/28 13:41

一、基本介绍
Android中极力推荐xmlpull方式解析xml。
xmlpull不仅可用在Android上同样也适用于javase,但在javase环境中需自己获取xmlpull所依赖的类库,kxml2-2.3.0.jar,xmlpull_1_1_3_4c.jar。

jar包下载网址
http://www.xmlpull.org/
http://kxml.sourceforge.net/

 

 

二、例子

读取到xml的声明返回数字0 START_DOCUMENT; 
读取到xml的结束返回数字1 END_DOCUMENT ; 
读取到xml的开始标签返回数字2 START_TAG 
读取到xml的结束标签返回数字3 END_TAG 
读取到xml的文本返回数字4 TEXT

<?xml version="1.0" encoding="UTF-8"?><people><person id="001"><name>XY1</name><age>22</age></person><person id="002"><name>XY2</name><age>22</age></person></people>

 

public class PersonService{/** * 从XML文件中读取数据 *  * @param xml XML文件输入流 */public List<Person> getPeople(InputStream xml) throws Exception{List<Person> lst = null;Person person = null;// 获得pull解析器工厂XmlPullParserFactory pullParserFactory = XmlPullParserFactory.newInstance();//获取XmlPullParser的实例XmlPullParser pullParser = pullParserFactory.newPullParser();// 设置需要解析的XML数据pullParser.setInput(xml, "UTF-8");// 取得事件int event = pullParser.getEventType();// 若为解析到末尾while (event != XmlPullParser.END_DOCUMENT) // 文档结束{// 节点名称String nodeName = pullParser.getName();switch (event){case XmlPullParser.START_DOCUMENT: // 文档开始lst = new ArrayList<Person>();break;case XmlPullParser.START_TAG: // 标签开始if ("person".equals(nodeName)){String id = pullParser.getAttributeValue(0);person = new Person();person.setId(id);}if ("name".equals(nodeName)){String name = pullParser.nextText();person.setName(name);}if ("age".equals(nodeName)){int age = Integer.valueOf(pullParser.nextText());person.setAge(age);}break;case XmlPullParser.END_TAG: // 标签结束if ("person".equals(nodeName)){lst.add(person);person = null;}break;}event = pullParser.next(); // 下一个标签}return lst;}}
原文地址——传送门
1 0
原创粉丝点击