XmlPull 解析器的使用

来源:互联网 发布:淘宝应用权限设置 编辑:程序博客网 时间:2024/06/02 19:28
XML文件的解析方式
    能够运用在Android系统上解析XML文件的常用有三种方式:DOM、SAX和PULL,其中DOM解析XML是先把XML文件读进内存中,再通过接口获取数据,该方法使用相对小的XML文件,移动设备往往受硬件性能影响,如果XML文件比较大使用DOM解析往往效率跟不上;SAX和PULL都是采用事件驱动方式来进行解析,在Android中的事件机制是基于回调函数。
    本例旨在考虑简单方便性,综合考虑选择了PULL解析,PULL解析器是一个开源项目,Android平台已经内置了PULL解析器,同时Android系统本身也是使用PULL解析器来解析各种XML文档。
    1、事件回调类型
    PULL解析XML文件时,回调XmlResourceParser内定义表示文档开头结束和节点开头结束的数值(事件回调类型),表示如下:
a.读取到XML文档开头(声明)返回:XmlPullParser.START_DOCUMENT (0)
b.读取到XML文档结束返回:XmlPullParser.END_DOCUMENT (1)
c.读取到XML节点开始返回:XmlPullParser.START_TAG (2)
d.读取到XML节点结束返回:XmlPullParser.END_TAG (3)
e.读取到XML文本返回:XmlPullParser.TEXT (4)
   
2、XmlPullParser有几个主要方法(更多查阅Android APIs):
a.XmlPullParser.getEventType() : Returns the type of the current event (START_TAG, END_TAG, TEXT, etc.) 【获取当前事件回调类型】
b.XmlPullParser.getName():For START_TAG or END_TAG events, the (local) name of the current element is returned when namespaces are enabled.【获取当前节点名字】
c.XmlPullParser.getAttributeValue(int index):Returns the given attributes value.【根据id获取节点属性值】
d.XmlPullParser.getAttributeValue(String namespace, String name):Returns the attributes value identified by namespace URI and namespace localName.【根据name获取节点属性值】
e.XmlPullParser.netxText():If current event is START_TAG then if next element is TEXT then element content is returned or if next event is END_TAG then empty string is returned, otherwise exception is thrown.【回调节点START_TAG时,通过此方法获取节点内容】




3、实际编码中如何使用
    在实际编码中,主要根据事件回调类型,结合被解析的XML结构进行解析提取数据,PULL解析XML文件的主要模式如下,更具体使用看本文提供的例子:
try {       //开始解析事件        int eventType = parser.getEventType();          //处理事件,不碰到文档结束就一直处理        while (eventType != XmlPullParser.END_DOCUMENT) {            //因为定义了一堆静态常量,所以这里可以用switch            switch (eventType) {               case XmlPullParser.START_DOCUMENT:                   // 不做任何操作或初开始化数据                    break;                  case XmlPullParser.START_TAG:                   // 解析XML节点数据                    // 获取当前标签名字                    String tagName = parser.getName();                      if(tagName.equals("XXXTAGXXX")){                          // 通过getAttributeValue 和 netxText解析节点的属性值和节点值                       }                   break;                  case XmlPullParser.END_TAG:                   // 单节点完成,可往集合里边添加新的数据                    break;               case XmlPullParser.END_DOCUMENT:                      break;           }              // 别忘了用next方法处理下一个事件,不然就会死循环            eventType = parser.next();       }   } catch (XmlPullParserException e) {       e.printStackTrace();   }catch (IOException e) {       e.printStackTrace();   }

原创粉丝点击