·您现在的位置: 云翼网络 >> 文章中心 >> 网站建设 >> app软件开发 >> Android开发 >> 实例解析Android中使用Pull解析器解析XML的方法

实例解析Android中使用Pull解析器解析XML的方法

作者:佚名      Android开发编辑:admin      更新时间:2022-07-23

1.Pull简介
Pull解析器是Android系统内置的的,Pull解析器与SAX解析器类似,他提供了类似的事件,如开始元素和介绍元素的事件,使用parser.next()可以进入下一个元素并触发相应的事件,然后进行相应的处理,当元素开始解析时,调用perser.nextText()方法就可以获取到下一个Text类型元素的值。

2.pull特点
(1)简单的结构,一个接口,一个另外,一个工厂组成了Pull解析器
(2)简单易用,Pull解析器只有一个重要的方法next(),他被用来检索下一个事件,而他的事件也仅仅只有五个,START_DOCUMENT, START_TAG ,TEXT, END_TAG, END_DOCUMENT
(3)最小的内存消耗,Pull解析器和SAX解析器一样,对内存的暂用少,但是SAX解析稍微有点繁琐,DOM很耗内存,所以Pull被推荐使用


3.src结构
项目包名为 com.pullxml.mypull,在src根目录下存在person.xml文件

-- com.pullxml.util
-- -- Person.java
-- com.pullxml.mypull
-- -- MainAcitivity.java
-- com.pullxml.service
-- -- PullService.java
-- com.pullxml.test
-- -- PullTester.java
-- person.xml

4.示例 Pull解析XML
先在src目录先新建一个android.xml

<?xml version="1.0" encoding="UTF-8"?> 
<persons> 
  <person id="23"> 
    <name>xiaanming</name> 
    <age>23</age> 
  </person> 
  <person id="20"> 
    <name>liudehua</name> 
    <age>28</age> 
  </person> 
</persons> 

新建一个PullXMLService

package com.example.pull_parser; 
 
import java.io.InputStream; 
import java.util.ArrayList; 
import java.util.List; 
 
import org.xmlpull.v1.XmlPullParser; 
 
import android.util.Log; 
import android.util.Xml; 
 
public class PullXMLService { 
  public static List<Person> readXML() throws Exception{ 
    //获取src目录下面的android.xml文件的输入流 
    InputStream is = PullXMLService.class.getClassLoader().getResourceAsStream("android.xml"); 
    //用来存放解析的Person对象 
    List<Person> persons = null; 
    //一个标记 
    boolean flag = false; 
    Person person = null; 
     
    //实例化一个XmlPullParser对象 
    XmlPullParser parser = Xml.newPullParser(); 
     
    //设置输入流和编码 
    parser.setInput(is, "UTF-8"); 
     
    //触发了第一个事件,根据XML的语法,也就是从他开始了解文档 
    int eventCode = parser.getEventType(); 
     
    //如果获得的事件码如果是文档的结束,那么解析结束 
    while (eventCode != XmlPullParser.END_DOCUMENT) { 
      switch(eventCode){ 
      case XmlPullParser.START_DOCUMENT:{ 
        //开始解析的时候我们一般做一些初始化的操作 
        persons = new ArrayList<Person>(); 
        break; 
      } 
      case XmlPullParser.START_TAG:{ 
        //判断当前的元素是否是需要检索的元素 
        if("person".equals(parser.getName())){ 
          flag = true; 
          person = new Person(); 
          person.setId(Integer.valueOf(parser.getAttributeValue(0))); 
        } 
        if(flag){ 
          if("name".equals(parser.getName())){ 
            person.setName(parser.nextText()); 
          }else if("age".equals(parser.getName())){ 
            person.setAge(Integer.valueOf(parser.nextText())); 
          } 
        } 
        break; 
      } 
      case XmlPullParser.END_TAG:{ 
        if("person".equals(parser.getName()) && person != null){ 
          flag = false; 
          persons.add(person); 
          Log.e("log", person.toString()); 
          person = null; 
        } 
        break; 
      } 
      } 
       
      //这一步很重要,该方法返回一个事件码,也是触发下一个事件的方法 
      eventCode = parser.next(); 
    } 
     
    return persons; 
     
  } 
}