欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

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

程序员文章站 2024-03-31 14:17:04
1.pull简介 pull解析器是android系统内置的的,pull解析器与sax解析器类似,他提供了类似的事件,如开始元素和介绍元素的事件,使用parser.next...

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; 
     
  } 
}