Android开发之XML文件的解析的三种方法--转载(三)

PULL方式
除了可以使用 SAX和DOM解析XML文件,也可以使用Android内置的Pull解析器解析XML文件。 Pull解析器的运行方式与 SAX 解析器相似。它也是事件触发的。Pull解析方式让应用程序完全控制文档该怎么样被解析。比如开始和结束元素事件,使用parser.next()可以进入下一个元素并触发相应事件。通过Parser.getEventType()方法来取得事件的代码值,解析是在开始时就完成了大部分处理。事件将作为数值代码被发送,因此可以使用一个switch对感兴趣的事件进行处理。
Pull解析是一个遍历文档的过程,每次调用next(),nextTag(), nextToken()和nextText()都会向前推进文档,并使Parser停留在某些事件上面,但是不能倒退。然后把文档设置给Parser。
Android中对Pull方法提供了支持的API,主要是
org.xmlpull.v1.XmlPullParser; 
org.xmlpull.v1.XmlPullParserFactory; 
二个类,其中主要使用的是XmlPullParser,XmlPullParserFactory是一个工厂,用于构建XmlPullParser对象。
应用程序通过调用XmlPullParser.next()等方法来产生Event,然后再处理Event。
       我们仍然拿上述天气预报的XML文件的一部分来做例子。
例如:需要解析的XML文件是:
[java] view plaincopy
<forecast_conditions>  
<day_of_week data="周三"/>  
<low data="22"/>  
<high data="29"/>  
<icon data="/ig/images/weather/chance_of_rain.gif"/>  
<condition data="可能有雨"/>  
</forecast_conditions>  
这部分XML文件中day_of_week,low,high等是TAG,data是ATTRIBUTEA。当然,如果有<></>夹在开始和结束符号之间的部分,则为TXET。
要想解析文档先要构建一个XmlPullParser对象。
[java] view plaincopy
final XmlPullParserFactory factory = XmlPullParserFactory.newInstance();   
factory.setNamespaceAware(true);   
final XmlPullParser parser = factory.newPullParser();   
parser.setInput(new StringReader("xmlStr");  
这里的xmlStr就是上边的XML文件。
此时,文档刚被初始化,所以它应该位于文档的开始,事件为START_DOCUMENT,可以通过XmlPullParser.getEventType()来获取。然后调用next()会产生
START_TAG,这个事件告诉应用程序一个标签已经开始了,调用getName()会返回" day_of_week ";若有TEXT,则再next()会产生TEXT事件,调用getText()会返回TEXT,由于此处没有,所以再next(),会产生END_TAG,这个告诉你一个标签已经处理完了,再next()直到最后处理完TAG,会产生END_DOCUMENT,它告诉你整个文档已经处理完成了。除了next()外,nextToken()也可以使用,只不过它会返回更加详细的事件,比如COMMENT, CDSECT, DOCDECL, ENTITY等等非常详细的信息。如果程序得到比较底层的信息,可以用nextToken()来驱动并处理详细的事件。需要注意一点的是TEXT事件是有可能返回空白的White Spaces比如换行符或空格等。
nextTag()--会忽略White Spaces,如果可以确定下一个是START_TAG或END_TAG,就可以调用nextTag()直接跳过去。通常它有二个用处:当START_TAG时,如果能确定这个TAG含有子TAG,那么就可以调用nextTag()产生子标签的START_TAG事件;当END_TAG时,如果确定不是文档结尾,就可以调用nextTag()产生下一个标签的START_TAG。在这二种情况下如果用next()会有TEXT事件,但返回的是换行符或空白符。
nextText()--只能在START_TAG时调用。当下一个元素是TEXT时,TEXT的内容会返回;当下一个元素是END_TAG时,也就是说这个标签的内容为空,那么空字串返回;这个方法返回后,Parser会停在END_TAG上。
核心代码如下所示:
[java] view plaincopy
myPULL.setOnClickListener(new Button.OnClickListener(){  
            @Override  
            public void onClick(View v) {  
                try{  
                    String url = "http://www.google.com/ig/api?&weather=beijing";  
                    DefaultHttpClient client = new DefaultHttpClient();   
                    HttpUriRequest req = new HttpGet(url);   
                    HttpResponse resp = client.execute(req);   
                    HttpEntity ent = resp.getEntity();   
                      
                    InputStream stream = ent.getContent(); //将文件导入流,因此用InputStream  
                    XmlPullParserFactory factory = XmlPullParserFactory.newInstance();  
                    factory.setNamespaceAware(true);  
                    XmlPullParser xpp = factory.newPullParser();  
                    xpp.setInput(stream, null);  
                    //xpp.setInput( new StringReader ( "<foo>Hello World!</foo>" ) );  
                    int eventType = xpp.getEventType();  
                    while (eventType != XmlPullParser.END_DOCUMENT) {  
                        if(eventType == XmlPullParser.START_DOCUMENT) {  
                            System.out.println("Start document");  
                        } else if(eventType == XmlPullParser.START_TAG) {  
                            System.out.println("Start tag "+xpp.getName());  
                            if(xpp.getName().equals("high")){  
                                j++;  
                                if(j==2){  
                                    highestTmp.setText(String.valueOf((Integer.parseInt(xpp.getAttributeValue(0))-32)*5/9));                             
                                }  
                            }  
                        } else if(eventType == XmlPullParser.END_TAG) {  
                            System.out.println("End tag "+xpp.getName());  
                        } else if(eventType == XmlPullParser.TEXT) {  
                            System.out.println("Text "+xpp.getText());  
                        }  
                        eventType = xpp.next();  
                    }  
                    System.out.println("End document");  
                    }  
                    catch(Exception e){  
                        e.printStackTrace();  
                    }  
                }     
            });   
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值