菜鸟学习之Android中pull解析xml原理

字数 777阅读 2018

我们在开发Android app的时候,常常用到对数据进行解析,最常用的就是对xml,与json解析。json基本都是用到解析框架,fast-json(阿里巴巴公司的开源框架,号称全世界最快),Gson(Google公司开发的json解析框架)。xml的解析一般都是pull,sax,dom解析。
今天来分享一个pull解析的原理。这个是我要解析的xml数据的web页面,

QQ截图20160716142156.png

在android studio中写入pull解析代码

try {    
      XmlPullFactory factory=XmlPullParserFactory.newInstance();
      XmlPullParser parse=factory.newPullParser();  
      String text=" ";   
      parse.setInput(new StringReader(这个里面是你要解析的xml字符串));    
      int eventType=parse.getEventType();    
    //打印出开始解析的文件类型
      Log.i(TAG, eventType+"");
      //开始解析
      while(eventType!=parse.END_DOCUMENT){        
            String nodeName=parse.getName();     
            switch (eventType){          
                      case XmlPullParser.START_TAG:                
                              Log.i(TAG, nodeName);                  
                              if("appThree".equals(nodeName)){            
                                          parse.next();               
                                         text=parse.getText().trim();              
                                        Log.i(TAG, text+"");            
                                }             
                             break;  
                      case XmlPullParser.END_TAG:               
                             Log.i(TAG, nodeName);               
                             break;      
                      default:               
                             break;       
           }   
           eventType=parse.next();    
            //打印出每次解析eventType变化
          Log.i(TAG, eventType+"");
           }
} 
catch (XmlPullParserException e) {   
           e.printStackTrace();
}
catch (IOException e) {
    e.printStackTrace();
}

对里面做一个解释,我们首先创建了一个XmlPullParserFactory(pull解析工厂),通过解析工厂获得XmlPullParser(解析员),我们的解析员通过setInput(new StringReader(xml字符串))得到你想要解析的xml字符串。用一个循环进行解析。
int eventType=parse.getEventType();获取解析的类型。在pull解析当中有五种解析类型,分别是
XmlPullParser.START_DOCUMENT=0(开始解析文档),
XmlPullParser.EDN_DOCUMENT=1(结束解析文档),
XmlPullParser.START_TAG=2(开始解析标签),
XmlPullParser.END_TAG=3(结束解析标签);
XmlPullParser.TEXT=4(解析文本时用的);
先来看看我解析出来的结果:


QQ截图20160716141422.png

从上图可以看到看到,
XmlPullParser.START_DOCUMENT,与XmlPullParser.END_DOCUMENT只执行了一次。
在这个当中我们发现2,3,4都在不停的执行。所以我们可以总结pull解析的原理。拿下面这个来举例说明原理。


QQ截图20160716142156.png

pull解析这个xml字符串,首先从<?xml version="1.0" encoding="utf-8"?>开始解析,所以出现数字0.接下来进入开始标签<apps>显示数字2,此时会进入TEXT。这一点我开始也不理解,为什么会出现4,我改动了在<apps>后面加上一句话it is ok。原来<apps>后面是可以加上TEXT.这下就很清楚了。在浏览器上的效果图如下图:
QQ截图20160716142532.png

以此这么下去,遇到开始标签显示2,遇到结束标签显示3,遇到文本,无论你有没有写文本,它都在哪里,显示4.遇到结尾显示1.
这个就是pull解析的全部过程。
pull是依靠数字来做判断的xml解析方式,而且只能是从上往下。对于我们只想解析一个xml文档某条数据来说,就显得力不从心了。因为pull很傻,只能一步一步的解析。

可能大家对于怎么生成一个简单的xml数据格式web页面有所难度,我来讲讲怎么制作简单的xml数据格式的web页面。
需要的工具:Xmapp ,Sublime Text.
上官网下载Xmapp,windows平台只有一种xmapp安装包,所以无论你是32位的还是64位的都是用的是这个安装包,按照提示安装。安装完毕之后,开启Apache.如下图:

QQ截图20160716132733.png
QQ截图20160716144148.png

安装完毕之后,开启Apache.如下图:


QQ截图20160716132916.png

进入Xmapp的安装目录,找到一个hotdocs文件夹,进入,


QQ截图20160716133722.png

创建一个xml格式文本(创建一个文本文档,更改后缀名),


![Uploading QQ截图20160716133941_719312.png . . .]

假如是get_data.xml。


QQ截图20160716144922.png

用sublime text打开xml文件进行编辑。输入xml语法格式的数据。保存,一定要记得保存。

QQ截图20160716145005.png

此时在你的浏览器上输入:localhost/get_data.xml。此时就会在浏览器上显示你刚才编辑的数据。


QQ截图20160716145041.png

推荐阅读更多精彩内容