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包。

作者:依旧淡然
邮箱:menlsh@163.com
本文版权归作者所有,未经作者同意,严禁转载及用作商业传播,否则将追究法律责任。
原文地址:https://www.cnblogs.com/menlsh/p/3070226.html