文章目录

pull解析介绍

除了上一节学习的 dom4j 解析 xml,我们也可以使用 Android 内置的 Pull 解析器解析 XML 文件。

Pull 解析器的运行方式与 SAX 解析器相似。它也是事件触发的。Pull 解析方式让应用程序完全控制文档该怎么样被解析。比如开始和结束元素事件,使用​​parser.next()​​​可以进入下一个元素并触发相应事件。通过​​Parser.getEventType()​​方法来取得事件的代码值,解析是在开始时就完成了大部分的处理。事件将作为数值代码被发送,因此可以使用一个 switch 对感兴趣的事件进行处理。

Pull 解析是一个遍历文档的过程,每次调用​​next()​​​、​​nextTag()​​​、​​nextToken()​​​和​​nextText()​​​都会向前推进文档,并使​​parser​​停留在某些事件上面,但是不能倒退。然后把文档设置给Parser。它允许用户的应用程序代码从解析器中获取事件,这与 SAX 解析器自动将事件推入处理程序相反。

Pull 解析器小巧轻便,解析速度快,简单易用,非常适合在 Android 移动设备中使用,Android 系统内部在解析各种 XML 时也是用 Pull 解析器,Android 官方推荐开发者们使用 Pull 解析技术。Pull 解析技术是第三方开发的开源技术,它同样可以应用于JavaSE 开发。

SAX 与 Pull 的区别:SAX 解析器的工作方式是自动将事件处理器进行处理,因此不能控制事件的处理主动结束;而Pull 解析器的工作方式为允许应用程序代码主动从解析器中获取事件,正因为是主动获取事件,因此可以在满足了需要的条件后不再获取事件,结束解析。

优点: 解析速度快,占用资源少。
缺点: 数据不持久。
使用场合: 对于XML文档较大但只需要文档的一部分。

具体步骤

1、创建 xmlpull 解析器

XmlPullParser parser = Xml.newPullParser();
parser.setInput(is);

2、获取事件类型,并且配合 while 循环,不断驱动事件并且解析文档内容

int type = parser.getEventType();
while(type != XmlPullParser.END_DOCUMENT){
根据事件类型解析文档
向后继续驱动事件
type = parser.next();
}

举例

还是使用之前的 ​​books.xml​

private void parseBookXmLByPull() throws IOException, XmlPullParserException {
XmlPullParser parser = Xml.newPullParser();
InputStream is = getAssets().open("books.xml");
parser.setInput(is, "utf-8");
//执行时间驱动机制
int eventType = parser.getEventType();
//如果不是文档末尾
while (eventType != XmlPullParser.END_DOCUMENT) {
switch (eventType) {
//文档开始是执行
case XmlPullParser.START_DOCUMENT:
break;
//遇到开始标记时执行
case XmlPullParser.START_TAG:
String name = parser.getName();
if (name.equals("books")) {
} else if (name.equals("book")) {
} else {
Log.d("info", "遇到开始标签,标签名称:" + parser.getName() + " 标签中的内容:" + parser.nextText());
}
break;
//结束标记
case XmlPullParser.END_TAG:
Log.d("info", "遇到结束标签,标签名称:" + parser.getName());
break;
}
eventType = parser.next();
}
}

运行程序查看日志
【达内课程】pull解析xml_xml
参考:
​​​Android之Pull解析XML​