android解析xml文件的方式

发布于 2022-10-15 09:31:33 字数 7419 浏览 21 评论 0

转: 东子哥

android解析xml文件的方式




上一节中,我们使用SAX方式解析xml文档, SAX方式是基于事件驱动的。当然android的事件机制是基于回调函数的。在这一节中,我们用另外一种方式解析xml文档,这种方式也是基于事件驱动的,与SAX方式一样,它就是PULL方式。只不过PULL方式读xml回调方法返回的是数字。

   读取到xml的声明返回      START_DOCUMENT;
   读取到xml的结束返回       END_DOCUMENT ;
   读取到xml的开始标签返回 START_TAG
   读取到xml的结束标签返回 END_TAG
   读取到xml的文本返回       TEXT
xml数据结果还是采用我们先前使用的river.xml文件。

采用PULL方式与SAX大同小异,重点在于我们需要知道导航到什么标签时候做什么就行了,依据上一节SAX处理方式的思路,我们也可以在这一节中一样处理,基本方法是:

基本处理方式是:当PULL解析器导航到文档开始标签时就开始实例化list集合用来存贮数据对象。导航到元素开始标签时回判断元素标签类型,如果是river标签,则需要实例化River对象了,如果是其他类型,则取得该标签内容并赋予River对象。当然它也会导航到文本标签,不过在这里,我们可以不用。

根据以上的解释,我们可以得出以下处理xml文档逻辑:

1:当导航到XmlPullParser.START_DOCUMENT,可以不做处理,当然你可以实例化集合对象等等。

2:当导航到XmlPullParser.START_TAG,则判断是否是river标签,如果是,则实例化river对象,并调用getAttributeValue方法获取标签中属性值。

3:当导航到其他标签,比如Introduction时候,则判断river对象是否为空,如不为空,则取出Introduction中的内容,nextText方法来获取文本节点内容

4:当然啦,它一定会导航到XmlPullParser.END_TAG的,有开始就要有结束嘛。在这里我们就需要判读是否是river结束标签,如果是,则把river对象存进list集合中了,并设置river对象为null.

由以上的处理逻辑,我们可以得出以下代码:

View Code
  1. public List<River> parse(String xmlPath){
  2.         List<River> rivers=new ArrayList<River>();
  3.         River river=null;
  4.         InputStream inputStream=null;
  5.             //获得XmlPullParser解析器
  6.         XmlPullParser xmlParser = Xml.newPullParser();
  7.            try {
  8.             //得到文件流,并设置编码方式
  9.             inputStream=this.context.getResources().getAssets().open(xmlPath);
  10.             xmlParser.setInput(inputStream, "utf-8");
  11.             //获得解析到的事件类别,这里有开始文档,结束文档,开始标签,结束标签,文本等等事件。
  12.             int evtType=xmlParser.getEventType();
  13.          //一直循环,直到文档结束
  14.              while(evtType!=XmlPullParser.END_DOCUMENT){
  15.              switch(evtType){
  16.              case XmlPullParser.START_TAG:
  17.                 String tag = xmlParser.getName();
  18.                  //如果是river标签开始,则说明需要实例化对象了
  19.                 if (tag.equalsIgnoreCase(RIVER)) {
  20.                     river = new River();
  21.                    //取出river标签中的一些属性值
  22.                  river.setName(xmlParser.getAttributeValue(null, NAME));
  23.                   river.setLength(Integer.parseInt(xmlParser.getAttributeValue(null, LENGTH)));
  24.                 }else if(river!=null){
  25.                     //如果遇到introduction标签,则读取它内容
  26.                     if(tag.equalsIgnoreCase(INTRODUCTION)){
  27.                     river.setIntroduction(xmlParser.nextText());
  28.                     }else if(tag.equalsIgnoreCase(IMAGEURL)){
  29.                         river.setImageurl(xmlParser.nextText());
  30.                     }
  31.                 }
  32.                 break;
  33.                            case XmlPullParser.END_TAG:
  34.              //如果遇到river标签结束,则把river对象添加进集合中
  35.                if (xmlParser.getName().equalsIgnoreCase(RIVER) && river != null) {
  36.                     rivers.add(river);
  37.                     river = null;
  38.                 }
  39.                break;
  40.                 default:break;
  41.             }
  42.             //如果xml没有结束,则导航到下一个river节点
  43.             evtType=xmlParser.next();
  44.          }
  45.         } catch (XmlPullParserException e) {
  46.             // TODO Auto-generated catch block
  47.             e.printStackTrace();
  48.         }catch (IOException e1) {
  49.             // TODO Auto-generated catch block
  50.             e1.printStackTrace();
  51.         }
  52.         return rivers;
  53.      }
复制代码运行结果与其他2个一样:

1.jpg (47.7 KB, 下载次数: 4)

下载附件

2011-04-15 11:03 上传

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文