• Android学习笔记43-XML文件解析(Pull方式)


    解析XML文档的方法是很多的,除了常用的SAX和DOM方法以外,还可以使用Java自带的Pull来解析XML文档。

     

    1.使用Pull解析器解析XML文档

      Pull解析器的运行方式和SAX解析器很相似,它提供了类似的事件,比如文档开始、文档结束、开始元素和结束元素等。使用parser.next()方法可以进入下一个元素并触发相应的事件。各种事件均已数字的形式被发送,因此可以在程序中使用一个switch语句来对事件进行选择,然后进行相应的事件处理。

    1.1事件类型

      Pull解析器提供的事件类型总共有5种,分别如下:

      (1)START_DOCUMENT         文档开始

      (2)START_TAG         开始元素

      (3)TEXT           文本

      (4)END_TAG        结束元素

      (5)END_DOCUMENT     文档结束

    1.2常用方法

      使用Pull解析器XmlPullParser解析XML文档时,主要会用到以下几个常用方法。

      (1)int getAttributeCount();         //获取当前元素的属性个数

      (2)String getAttributeValue(int index);   //获取属性值

      (3)int getEventType();           //获取事件类型

      (4)String getName();             //用于START_TAG和END_TAG事件中,获取当前元素的名字

      (5)int next();                 //处理下一个元素

      (6)int nextText();              //用于START_TAG事件中,获得下一个TEXT类型的元素

    1.3创建Pull解析器

      可以通过以下两个步骤创建一个Pull解析器。

      (1)通过调用XmlPullParserFactory工厂类的newInstance()方法,创建一个Pull解析器工厂对象。

      (2)通过调用Pull解析器工厂对象的newPullParser()方法,创建一个Pull解析器对象。

      创建好了Pull解析器对象之后,就可以通过调用Pull解析器对象的setInput()方法传入想要解析的XML文档了。其中,setInput()方法提供了两种重载的形式,分别为:

      (1)void setInput(Reader in);

      (2)void setInput(InputStream inputStream, String inputEncoding);

    1.4实例

      如下的代码使用Pull解析器对上两篇博文中提到的“person.xml”文档进行了解析,提取出了XML文档中的person信息,并存储到了Person对象列表。

    复制代码
     1     /*
     2      * Function :   使用Pull解析器解析XML文档
     3      * Param   :  inputStream      以输入流的形式传入XML文档
     4      *               inputEncoding     XML文档的编码格式
     5      * Retuen  :    List<Person>     Person对象列表
     6      * Author  :    博客园-依旧淡然
     7      */
     8     public static List<Person> readXML(InputStream inputStream, String inputEncoding) throws Exception {
     9         
    10         List<Person> list = null;            //存储解析得到的所有Person对象
    11         Person person = null;               //存储解析得到的单个Person对象
    12         
    13         XmlPullParserFactory factory = XmlPullParserFactory.newInstance();            //创建Pull解析器工厂
    14         XmlPullParser xmlPullParser = factory.newPullParser();         //创建Pull解析器
    15         xmlPullParser.setInput(inputStream, inputEncoding);            //以输入流的形式传入所要解析的XML文档
    16         
    17         int eventType = xmlPullParser.getEventType();         //获取事件类型
    18         while(eventType != XmlPullParser.END_DOCUMENT) {    
    19             switch(eventType) {
    20             case XmlPullParser.START_DOCUMENT:                //文档开始
    21                 list = new ArrayList<Person>();
    22                 break;
    23             case XmlPullParser.START_TAG:                     //开始元素
    24                 if(xmlPullParser.getName().equals("person")) {
    25                     person = new Person();
    26                     int id = Integer.parseInt(xmlPullParser.getAttributeValue(0));    //获取元素的属性值
    27                     person.setId(id);
    28                 } else if(xmlPullParser.getName().equals("name")) {
    29                     String name = xmlPullParser.nextText();    //获取元素的内容
    30                     person.setName(name);
    31                 } else if(xmlPullParser.getName().equals("age")) {
    32                     int age = Integer.parseInt(xmlPullParser.nextText());
    33                     person.setAge(age);
    34                 }
    35                 break;
    36             case XmlPullParser.END_TAG:                        //结束元素
    37                 if(xmlPullParser.getName().equals("person")) {
    38                     list.add(person);
    39                     person = null;
    40                 }
    41                 break;
    42             }
    43             eventType = xmlPullParser.next();            //产生循环,遍历所有元素
    44         }
    45         return list;
    46     }
    复制代码

      需要注意的一点是,使用Pull解析器时,需要在工程中导入kxml2-2.2.2.jar包。

  • 相关阅读:
    innerHTML与appendChild(newnodeText)的区别
    转]解析C语言中的sizeof
    #pragma 预处理指令详解
    Linux目录结构和常用命令
    Linux下select, poll和epoll IO模型的详解
    重载,继承,重写和多态的区别:
    CentOs7实现lvs+nginx+keepalived负载均衡(DR模式)
    shell中的通配符(grep、cut、sort等)
    kali虚拟机 联网问题解决办法
    MongoDB 数据库
  • 原文地址:https://www.cnblogs.com/britalient/p/3173276.html
Copyright © 2020-2023  润新知