XML解析之PULL

在Android中极力推荐的xmlpull方式解析xml。

为什么 STAX 解析方式 效率 好于 SAX ?

1、SAX 无选择性的,所有事件都会处理 解析方式,Stax 由用户控制需要处理事件类型

2、在使用Stax进行数据解析时,随时终止解析

环境:

xmlpull_1_1_3_4c.jar

http://www.xmlpull.org/    xmlpull

XML文件:

<?xml version="1.0" encoding="UTF-8"?><root>
    <student id="1" group="1">
        <name>张三</name>
        <sex>男</sex>
        <age>18</age>
        <email>[email protected]</email>
        <birthday>1987-06-08</birthday>
        <memo>好学生</memo>
    </student>
    <student id="2" group="2">
        <name>李四</name>
        <sex>女</sex>
        <age>18</age>
        <email>[email protected]</email>
        <birthday>1987-06-08</birthday>
        <memo>好学生</memo>
    </student>
    <student id="3" group="3">
        <name>小王</name>
        <sex>男</sex>
        <age>18</age>
        <email>[email protected]</email>
        <birthday>1987-06-08</birthday>
        <memo>好学生</memo>
    </student>
    <student id="4" group="4">
        <name>小张</name>
        <sex>男</sex>
        <age>18</age>
        <email>[email protected]</email>
        <birthday>1987-06-08</birthday>
        <memo>好学生</memo>
    </student>
    <student id="5" group="5">
        <name>小明</name>
        <sex>男</sex>
        <age>18</age>
        <email>[email protected]</email>
        <birthday>1987-06-08</birthday>
        <memo>好学生</memo>
    </student></root>

XML对应的实体文件:

public class Student {    
    private int id;    private int group;    private String name;    private String sex;    private int age;    private String email;    private String memo;    private String birthday;    public int getId() {        return id;
    }    public void setId(int id) {        this.id = id;
    }    public int getGroup() {        return group;
    }    public void setGroup(int group) {        this.group = group;
    }    public String getName() {        return name;
    }    public void setName(String name) {        this.name = name;
    }    public String getSex() {        return sex;
    }    public void setSex(String sex) {        this.sex = sex;
    }    public int getAge() {        return age;
    }    public void setAge(int age) {        this.age = age;
    }    public String getEmail() {        return email;
    }    public void setEmail(String email) {        this.email = email;
    }    public String getMemo() {        return memo;
    }    public void setMemo(String memo) {        this.memo = memo;
    }    public String getBirthday() {        return birthday;
    }    public void setBirthday(String birthday) {        this.birthday = birthday;
    }
    
}

Pull解析代码

public class PullParseXml {    
    
    public List<Student> PullParseXML(){
        
        List<Student> list=null;
        Student student = null;        
        //构建XmlPullParserFactory
        try {
            XmlPullParserFactory pullParserFactory=XmlPullParserFactory.newInstance();            //获取XmlPullParser的实例
            XmlPullParser xmlPullParser=pullParserFactory.newPullParser();            //设置输入流  xml文件
            xmlPullParser.setInput(Thread.currentThread().getContextClassLoader().getResourceAsStream("Student.xml"), "UTF-8");            
            //开始
            int eventType=xmlPullParser.getEventType();            
            try {                while(eventType!=XmlPullParser.END_DOCUMENT){
                    String nodeName=xmlPullParser.getName();                    switch (eventType) {                    //文档开始
                    case XmlPullParser.START_DOCUMENT:
                        list=new ArrayList<Student>();                        break;                    //开始节点
                    case XmlPullParser.START_TAG:                        //判断如果其实节点为student
                        if("student".equals(nodeName)){                            //实例化student对象
                            student=new Student();                            //设置Id属性
                            student.setId(Integer.parseInt(xmlPullParser.getAttributeValue(0)));                            //设置Group属性
                            student.setGroup(Integer.parseInt(xmlPullParser.getAttributeValue(1)));
                        }else if("name".equals(nodeName)){                            //设置name                            student.setName(xmlPullParser.nextText());
                        }else if("sex".equals(nodeName)){                            //设置sex                            student.setSex(xmlPullParser.nextText());
                        }else if("age".equals(nodeName)){                            //设置age                            student.setAge(Integer.parseInt(xmlPullParser.nextText()));
                        }else if("email".equals(nodeName)){                            //设置email                            student.setEmail(xmlPullParser.nextText());
                        }else if("birthday".equals(nodeName)){                            //设置birthday                            student.setBirthday(xmlPullParser.nextText());
                        }else if("memo".equals(nodeName)){                            //设置memo属性                            student.setMemo(xmlPullParser.nextText());
                        }                        break;                    //结束节点
                    case XmlPullParser.END_TAG:                        if("student".equals(nodeName)){
                            list.add(student);
                            student=null;
                        }                        break;                    default:                        break;
                    }
                    eventType=xmlPullParser.next();
                }
            } catch (NumberFormatException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
        } catch (XmlPullParserException e) {
            e.printStackTrace();
        }        return list;
    }    
    public static void main(String[] args) {
        List<Student> list=new PullParseXml().PullParseXML();        for(Student student:list){
            System.out.println("id:"+student.getId()+"\tgroup:"+student.getGroup()+"\tname:"+student.getName()+"\tsex:"+student.getSex()+"\tage:"+student.getAge()+"\temail:"+student.getEmail()+"\tbirthday:"+student.getBirthday()+"\tmemo:"+student.getMemo());
        }
    }
    
}

Event_Type事件返回的事件代码:

public static final java.lang.String NO_NAMESPACE = "";  
  public static final int START_DOCUMENT = 0;  
  public static final int END_DOCUMENT = 1;  
  public static final int START_TAG = 2;  
  public static final int END_TAG = 3;  
  public static final int TEXT = 4;  
  public static final int CDSECT = 5;  
  public static final int ENTITY_REF = 6;  
  public static final int IGNORABLE_WHITESPACE = 7;  
  public static final int PROCESSING_INSTRUCTION = 8;  
  public static final int COMMENT = 9;  
  public static final int DOCDECL = 10;

对XML数据通过PULL解析器进行CURD示意图:

时间: 2024-10-16 07:50:58

XML解析之PULL的相关文章

几种常见的xml解析方式 SAX,DOM,PULL以android为例

准备工作 首先是一个person.xml文件 <?xml version="1.0" encoding="UTF-8"?> <persons> <person id="18"> <name>allen</name> <age>36</age> </person> <person id="28"> <name>

Android中XML解析-PULL解析

前面写了两篇XML解析的Dom和SAX方式,Dom比较符合思维方式,SAX事件驱动注重效率,除了这两种方式以外也可以使用Android内置的Pull解析器解析XML文件. Pull解析器的运行方式与 SAX 解析器相似,也是事件触发的.Pull解析方式让应用程序完全控制文档该怎么样被解析,比如开始和结束元素事件,使用parser.next()可以进入下一个元素并触发相应事件.通过Parser.getEventType()方法来取得事件的代码值,解析是在开始时就完成了大部分处理.事件将作为数值代码

关于XML文档pull解析的新思考-内省的应用

今天,复习黑马第6天学习的pull解析XML文档,结合第10天讲的JavaBean,突然了有了新的思考. 以下是我创建的XML文档: <?xml version="1.0" encoding="UTF-8"?> <!-- 定义一个演示文档,存储黑马的所有班级,以及每个班级的信息 利用XML的功能之一:XML用来表示生活中有关系的数据  -->  <itheima>   <class>   <name>Anr

非常简单的XML解析(SAX解析、pull解析)

这里只是把解析的数据当日志打出来了 非常简单的xml解析方式 1 package com.example.demo.service; 2 3 import java.io.IOException; 4 import java.io.InputStream; 5 6 import javax.xml.parsers.DocumentBuilder; 7 import javax.xml.parsers.DocumentBuilderFactory; 8 import javax.xml.parse

Android开发之XML解析PULL

Android中解析xml是非常常用的操作,除了SAX和DOM两种最常用的解析xml外,Android内置的Pull解析器解析XML文件. 在Android的源码中大量的使用Pull解析,pull不仅更加的面相对象,而且使用速度和效率更高. Pull解析器是一个开源的java项目,既可以用于android,也可以用于JavaEE.如果用在javaEE需要把其jar文件放入类路径中,因为Android已经集成进了Pull解析器,所以无需添加任何jar文件.android系统本身使用到的各种xml文

Android中的三种XML解析方式

在Android中提供了三种解析XML的方式:SAX(Simple API XML),DOM(Document Objrect Model),以及Android推荐的Pull解析方式.下面就对三种解析方式一一详细阐述. 假设要要解析person.xml文档 <?xml version="1.0" encoding="UTF-8"?><persons>  <person id="1">    <name&g

Android xml 解析

XML 常用的三种解析方式: DOM: 全部加载到内存,生成一个树状结构,占用内存比较大. SAJ: 采用事件驱动,速度快,效率高,不支持回退. PULL:也是采用事件驱动,语法简洁. 步骤: 1. 创建XML 解析器:XmlPullParser parser = Xml.newPullParser(); 2. 配置解析器:parser.setInput(is, "utf-8");// 参数为 xml 文件输入流 和 编码方式. 3. 根据事件进行解析. int type = pars

Android 之xml解析

HTTP网络传输中的数据组织方式有三种方式:1.HTML方式2.XML方式 3.JSON方式 XML称为可扩展标记语言,它与HTML一样,都是SGML(标准通用标记语言) XML是Internet环境中跨平台的,依赖于内容技术,是当前处理结构化文档信息的有力工具,可扩展标记语言XML是一种简单的数据存储语言,使用一系列简单的标记描述数据. xml文件的节点的种类,一种是ElementNode,一种是TextNode.像<persons>.<person>这种节点就属于Element

android-XML解析之pull类型代码解析

由于之前的项目使用过xml文件的解析,但是在使用的时候都是从网上找到的代码,稍作修改就使用了,然而对其中的原理并不知所以然,所以再次想使用的时候,感觉还是空空的,不知道如何下手,为了更加深入的理解xml文件的解析,我从代码实现的角度做一些理解,但是我在看代码的时候,有些代码的实现还是没有办法读懂,还是太深奥.下面我就以我之见,写一些东西,作为记录. 在android中XML的解析有三种,分别为:SAX(Simple API XML).DOM(document object model).以及今天