Android使用pull解析xml
一、理论准备
Pull解析器的运行方式与 SAX 解析器相似。它提供了类似的事件,如:开始元素和结束元素事件,使用parser.next()可以进入下一个元素并触发相应事件。跟SAX不同的是, Pull解析器产生的事件是一个数字,而非方法,因此可以使用一个switch对感兴趣的事件进行处理。当元素开始解析时,调用parser.nextText()方法可以获取下一个Text类型节点的值。
工程结构如下:

为什么把xml放在assets目录下呢,它和res/values目录的区别是系统不分配ID,好像没解决问题,暂时没查到资料。
二、上代码
package com.example.and_0003;import java.io.InputStream;import java.util.List;import com.hpu.entity.Student;import com.hpu.util.PullService;import android.app.Activity;import android.content.res.AssetManager;import android.os.Bundle;import android.util.Log;public class MainActivity extends Activity {/** Called when the activity is first created. */@Overridepublic void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);AssetManager asset = getAssets();try {InputStream input = asset.open("student.xml");List<Student> list = PullService.getStudents(input);for (Student stu : list) {Log.e("StudentInfo","Person ID: " + stu.getId() + ","+ stu.getName() + ", " + stu.getAge() + ", "+ stu.getSex());}} catch (Throwable e) {e.printStackTrace();}}}
1: <?xml version="1.0" encoding="utf-8"?>2: <students>3: <student id="20110806100">4: <name>小明</name>5: <age>22</age>6: <sex>男</sex>7: </student>8: <student id="20110806101">9: <name>小李</name>10: <age>24</age>11: <sex>男</sex>12: </student>13: <student id="20110806102">14: <name>小丽</name>15: <age>21</age>16: <sex>女</sex>17: </student>18: </students>
package com.hpu.entity;
public class Student { private String id;
private String name;
private int age;
private String sex; public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
} }
1: package com.hpu.util;2:3: import java.io.InputStream;4: import java.util.ArrayList;5: import java.util.List;6:7: import org.xmlpull.v1.XmlPullParser;8: import org.xmlpull.v1.XmlPullParserFactory;9:10: import com.hpu.entity.Student;11:12: import android.util.Xml;13:14: public class PullService {15:16: // 采用XmlPullParser来解析XML文件17: public static List<Student> getStudents(InputStream inStream)18: throws Throwable {19: List<Student> students = null;20: Student mStudent = null;21:22: // ========创建XmlPullParser,有两种方式=======23: // 方式一:使用工厂类XmlPullParserFactory24: XmlPullParserFactory pullFactory = XmlPullParserFactory.newInstance();25: XmlPullParser parser = pullFactory.newPullParser();26: // 方式二:使用Android提供的实用工具类android.util.Xml27: // XmlPullParser parser = Xml.newPullParser();28:29: // 解析文件输入流30: parser.setInput(inStream, "UTF-8");31: // 产生第一个事件32: int eventType = parser.getEventType();33: // 只要不是文档结束事件,就一直循环34: while (eventType != XmlPullParser.END_DOCUMENT) {35: switch (eventType) {36: // 触发开始文档事件37: case XmlPullParser.START_DOCUMENT:38: students = new ArrayList<Student>();39: break;40: // 触发开始元素事件41: case XmlPullParser.START_TAG:42: // 获取解析器当前指向的元素的名称43: String name = parser.getName();44: if ("student".equals(name)) {45: // 通过解析器获取id的元素值,并设置student的id46: mStudent = new Student();47: mStudent.setId(parser.getAttributeValue(0));48: }49: if (mStudent != null) {50: if ("name".equals(name)) {51: // 获取解析器当前指向元素的下一个文本节点的值52: mStudent.setName(parser.nextText());53: }54: if ("age".equals(name)) {55: // 获取解析器当前指向元素的下一个文本节点的值56: mStudent.setAge(new Short(parser.nextText()));57: }58: if ("sex".equals(name)) {59: // 获取解析器当前指向元素的下一个文本节点的值60: mStudent.setSex(parser.nextText());61: }62: }63: break;64: // 触发结束元素事件65: case XmlPullParser.END_TAG:66: //67: if ("student".equals(parser.getName())) {68: students.add(mStudent);69: mStudent = null;70: }71: break;72: default:73: break;74: }75: eventType = parser.next();76: }77: return students;78: }79:80: }81:
四、运行结果

五、遗留问题及参考文献
Dom和SAX和Pull的适用范围分别是什么?
http://blog.csdn.net/cjjky/article/details/6667744
Android使用pull解析xml的更多相关文章
- Android之Pull解析XML
一.Pull解析方法介绍 除了可以使用SAX和DOM解析XML文件,也可以使用Android内置的Pull解析器解析XML文件.Pull解析器的运行方式与SAX解析器相似.它也是事件触发的.Pull解 ...
- Android中用PULL解析XML
解析XML的方式有DOM,SAX,PULL,那为什么要在Android中使用PULL解析呢?首先来说一下PULL解析的优点,然后再说一下其他两种解析方式的缺点,答案就清晰可见啦. DOM不适合文档较大 ...
- android——使用pull解析xml文件
1.persons.xml 将persons.xml文件放到src目录下.其代码如下: <?xml version='1.0' encoding='UTF-8' standalone='yes' ...
- [android] 采用pull解析xml文件
/***********2016年5月6日 更新**********************/ 知乎:Android 中有哪几种解析 xml 的类,官方推荐哪种 ? 以及它们的原理和区别? 刘吉财: ...
- Android中pull解析XML文件的简单使用
首先,android中解析XML文件有三种方式,dom,sax,pull 这里先讲pull,稍候会说SAX和DOM pull是一种事件驱动的xml解析方式,不需要解析整个文档,返回的值是数值型,是推荐 ...
- Android使用pull解析xml格式的数据
dom解析:基于全文加载的解析方式 sax解析:基于事件的逐行解析方式 pull解析:同sax XmlPullParser //解析xml文件读取短信内容 ...
- 使用PULL解析XML文件
转载博文1:http://blog.csdn.net/wangkuifeng0118/article/details/7313241 XmlPull和Sax类似,是基于流(stream)操作文件,然后 ...
- Android——PULL解析XML
简介 Android中常常使用XML文件保存用户的APP设置信息.因此需要对XML文件的相关操作进行了解.本文将以<学生信息管理系统>为案例背景进行介绍相关的XML解析的介绍,以及其他相关 ...
- Android系列--DOM、SAX、Pull解析XML
您可以通过点击 右下角 的按钮 来对文章内容作出评价, 也可以通过左下方的 关注按钮 来关注我的博客的最新动态. 如果文章内容对您有帮助, 不要忘记点击右下角的 推荐按钮 来支持一下哦 如果您对文章内 ...
随机推荐
- android开发之wheel控件使用详解
出门在外生不起病呀,随便两盒药60多块钱.好吧,不废话了,今天我们来看看wheel控件的使用,这是GitHub上的一个开源控件,用起来十分方便,我们可以用它做许多事情,比如做一个自定义的datepic ...
- Mac中Eclipse配置Maven开发环境
1.下载Maven tar.gz包 http://maven.apache.org/download.cgi 2.解压tar包 随便一个路径都行 3.配置环境变量 bash设置~/.bash_prof ...
- 查看kindle paperwhite2上卡索引书籍的方法
昨天kindle耗电量突然加快,经过检查和网络搜索得知是卡索引导致的耗电量增大.我自己通过关闭索引的方式解决了这个问题. 在这个过程中发现了一个可以直接找到所有卡索引书籍的方法,在此分享一下. 首先打 ...
- Jquery Table添加行、删除行
html页面代码 <table id="tblUserInfo"> </table> Js代码 function DealUserInfo(qty){ ) ...
- ACM——A + B Problem (4)
A + B Problem (4) 时间限制(普通/Java):1000MS/3000MS 运行内存限制:65536KByte总提交:2496 测试通过:124 ...
- Android开发之Handler
我们都知道应用程序开启后,安卓会开启一个主线程(UI线程),主线程管理UI控件,进行事件分发.那为什么会出现Handler呢? 例如你要是点击一个 Button ,Android会分发事件到Butto ...
- 【转】【SQL SERVER】怎样处理作业中的远程服务器错误(42000)
(SQL SERVER)怎样处理作业中的远程服务器错误(42000) 问: 1.我创建了一个链接服务器. 2.在两台服务器之间创建了新的SQL用户. 3.编写了访问链接服务器的SQL语句,执行成功. ...
- Hibernate不同DB的日期查询
Java web项目开发,ORM层用的是Hibernate,用HQL语句查询不同数据库时,日期时间比较还是有所区别的. 1.在Mysql数据库时,是这样写的: 上面是个代码拼串截图,翻译一下是这样的: ...
- Dao模型设计(基于Dao与Hebernate框架)
以前没有Dao设计模型之前,一般都是这样的流程: ①先设计实体对象 学生对象: package com.itheima.domain; import java.io.Serializable; imp ...
- scrapy抓取到中文,保存到json文件为unicode,如何解决.
http://scrapy-chs.readthedocs.org/zh_CN/latest/intro/overview.html 以上链接是很好的scrapy学些资料.感谢marchtea的翻译. ...