• Android开发之XML文件的解析的三种方法


    转自http://blog.csdn.net/redoffice/article/details/7782770

    本文主要讲解Android开发中如何对XML文件的解析,由于XML文件具有与平台无关,广泛应用于数据通信中,因此解析XML文件就显得很有意义。Android对XML文件解析的方法主要有3种。 通常有三种方式:DOM、SAX和PULL,下面就分别针对这三种方式来进行讨论。

    假设我们在开发天气预报应用程序的时候,使用google给我们提供的API,以及天气预报数据,例如我们要获得北京当前的天气预报数据,即可在浏览器中输入如下地址:http://www.google.com/ig/api?&weather=beijing。 则可以看到一个XML文件展现在我们面前,对于此XML文件Google给我们的说明是:

    “This XML file does not appear to have any style informationassociated with it. The document tree is shown below”.即此XML文件没有任何样式信息,只有文档结构树的显示。

    文件内容如下所示:

    [html] view plaincopy
    1. <xml_api_reply version="1">  
    2. <weather module_id="0" tab_id="0" mobile_row="0" mobile_zipped="1" row="0" section="0">  
    3. <forecast_information>  
    4. <city data="Beijing, Beijing"/>  
    5. <postal_code data="beijing"/>  
    6. <latitude_e6 data=""/>  
    7. <longitude_e6 data=""/>  
    8. <forecast_date data="2012-07-24"/>  
    9. <current_date_time data="2012-07-24 15:30:00 +0000"/>  
    10. <unit_system data="SI"/>  
    11. </forecast_information>  
    12. <current_conditions>  
    13. <condition data="多云"/>  
    14. <temp_f data="77"/>  
    15. <temp_c data="25"/>  
    16. <humidity data="湿度: 78%"/>  
    17. <icon data="/ig/images/weather/cn_cloudy.gif"/>  
    18. <wind_condition data="风向: 东北、风速:2 米/秒"/>  
    19. </current_conditions>  
    20. <forecast_conditions>  
    21. <day_of_week data="周二"/>  
    22. <low data="22"/>  
    23. <high data="30"/>  
    24. <icon data="/ig/images/weather/cn_cloudy.gif"/>  
    25. <condition data="多云"/>  
    26. </forecast_conditions>  
    27. <forecast_conditions>  
    28. <day_of_week data="周三"/>  
    29. <low data="24"/>  
    30. <high data="30"/>  
    31. <icon data="/ig/images/weather/chance_of_rain.gif"/>  
    32. <condition data="可能有雨"/>  
    33. </forecast_conditions>  
    34. <forecast_conditions>  
    35. <day_of_week data="周四"/>  
    36. <low data="25"/>  
    37. <high data="29"/>  
    38. <icon data="/ig/images/weather/thunderstorm.gif"/>  
    39. <condition data="雷阵雨"/>  
    40. </forecast_conditions>  
    41. <forecast_conditions>  
    42. <day_of_week data="周五"/>  
    43. <low data="24"/>  
    44. <high data="31"/>  
    45. <icon data="/ig/images/weather/chance_of_storm.gif"/>  
    46. <condition data="可能有暴风雨"/>  
    47. </forecast_conditions>  
    48. </weather>  
    49. </xml_api_reply>  

    那么,我们要从中获取到天气的信息,就是要对此XML文件做解析。下面我们就分别用DOM,SAX和PULL三种方式,分别对此XML文件做解析。

    DOM方式

    DOM方式解析xml是先把xml文档都读到内存中,然后再用DOM API来访问树形结构,并获取数据。DOM解析的方式可以知道,如果XML文件很大的时候,处理效率就会变得比较低,这也是DOM方式的一个缺点。

    现在我们来解析上文中提到的有关天气预报信息相关的xml文件。什么是解析呢?说的通俗一点,就是将这个带标签的XML文件识别出来,并抽取一些相关的,对我们有用的信息来给我们使用。那在这个文件里,时间,天气,温度,以及图标对我们来说是需要得到的。我们要对其做解析。

    解析的具体思路是:

    1.   XML文件加载进来。

    2.   获取文档的根节点

    3.   获取文档根节点中所有子节点的列表

    4.   获取子节点列表中需要读取的节点信息

    根据这4个步骤,我们进行开发:

    首先就是如何加载XML文件,假设此文件来源于网络。

    [java] view plaincopy
    1. String url = "http://www.google.com/ig/api?&weather=beijing";  
    2. DefaultHttpClient client = new DefaultHttpClient();   
    3. HttpUriRequest req = new HttpGet(url);   
    4. HttpResponse resp = client.execute(req);   
    5. HttpEntity ent = resp.getEntity();   
    6. InputStream stream = ent.getContent();   
    7. DocumentBuilder myDocBuilder = DocumentBuilderFactory.newInstance().newDocumentBuilder();   
    8. Document myDoc = myDocBuilder.parse(new InputSource(stream));  

    首先创建一个DocumentBuilderFactory实例

    然后加载XML文档(Document

    加载完毕以后,就要进行节点获取操作,即第二步和第三步的操作:

    [java] view plaincopy
    1. //找到根Element  
    2. Element root=document.getDocumentElement();  
    3. //找到子节点forecast_conditions  
    4. NodeList nodes=root.getElementsByTagName(forecast_conditions);  
    假设我需要获得该XML文件中周三的最高气温,则可以用下列代码得到:
    [java] view plaincopy
    1. nodes.item(1).getChildNodes().item(2).getAttributes().item(0).getNodeValue();  
    nodes.item(1)表示包含标签forecast_conditions的第二个节点,从0开始计数。getChildNodes().item(2)表示获取标签forecast_conditions子节点的第三个条目节点,即high节点。.getAttributes().item(0)表示high节点的第一个属性,即data,最后的getNodeValue()表示得到此属性的属性值。

    SAX方式

    SAXSimple API for XML的缩写。是一个包也可以看成是一些接口。

    相比于DOM而言SAX是一种速度更快,更有效,占用内存更少的解析XML文件的方法。它是逐行扫描,可以做到边扫描边解析,因此SAX可以在解析文档的任意时刻停止解析。非常适用于Android等移动设备。

    SAX是基于事件驱动的。所谓事件驱动就是说,它不用解析完整个文档,在按内容顺序解析文档过程中,SAX会判断当前读到的字符是否符合XML文件语法中的某部分。如果符合某部分,则会触发事件。所谓触发事件,就是调用一些回调方法。当然android的事件机制是基于回调方法的,在用SAX解析xml文档时候,在读取到文档开始和结束标签时候就会回调一个事件,在读取到其他节点与内容时候也会回调一个事件。在SAX接口中,事件源是org.xml.sax包中的XMLReader,它通过parser()方法来解析XML文档,并产生事件。事件处理器是org.xml.sax包中ContentHanderDTDHanderErrorHandler,以及EntityResolver4个接口。

    这四个接口的详细说明如下:

    事件处理器名称

    事件处理器处理的事件

    XMLReader注册方法

    ContentHander

    XML文档的开始与结束,

    XML文档标签的开始与结束,接收字符数据,跳过实体,接收元素内容中可忽略的空白等。

    setContentHandler(ContentHandler h)

    DTDHander

    处理DTD解析时产生的相应事件

    setDTDHandler(DTDHandler h)

    ErrorHandler

    处理XML文档时产生的错误

    setErrorHandler(ErrorHandler h)

    EntityResolver

    处理外部实体

    setEntityResolver(EntityResolver e)

    我们用来做内容解析的回调方法一般都定义在ContentHandler接口中

    ContentHandler接口常用的方法:

    startDocument()  

         当遇到文档的开头的时候,调用这个方法,可以在其中做一些预处理的工作。
    endDocument()    

         当文档结束的时候,调用这个方法,可以在其中做一些善后的工作。 
    startElement(String namespaceURI, String localName,String qName, Attributes atts)    

         当读到开始标签的时候,会调用这个方法。namespaceURI就是命名空间,localName是不带命名空间前缀的标签名,qName是带命名空间前缀的标签名。通过atts可以得到所有的属性名和相应的值。
    endElement(String uri, String localName, String name)   

       在遇到结束标签的时候,调用这个方法。
    characters(char[] ch, int start, int length)    

        这个方法用来处理在XML文件中读到的内容。例如:<high data="30"/>主要目的是获取high标签中的值。

    第一个参数用于存放文件的内容,后面两个参数是读到的字符串在这个数组中的起始位置和长度,使用new String(ch,start,length)就可以获取内容。

    注意:

    SAX的一个重要特点就是它的流式处理,当遇到一个标签的时候,它并不会纪录下之前所碰到的标签,即在startElement()方法中,所有能够知道的信息,就是标签的名字和属性,至于标签的嵌套结构,上层标签的名字,是否有子元属等等其它与结构相关的信息,都是不知道的,都需要你的程序来完成。这使得SAX在编程处理上没有DOM方便。

    现在我们截取一段XML文件来做解析,其调用方法是这样的:

    <?xml version="1.0"?>         ---------->         startDocument()

    <weather>                               ---------->         startElement

    <forecast_information>       ---------->         startElement

    <city>                                       ---------->         startElement

    beijing                                     ---------->        characters

    </city>                                      ---------->        endElement

    </forecast_information >     ---------->        endElement

    </weather >                            ---------->        endElement

    文档结束                                 ---------->        endDocument()

    SAX的解析步骤:

    首先需要注意的是:

    SAX还为其制定了一个Helper类:DefaultHandler它实现了ContentHandler这个接口,但是其所有的方法体都为空,在实现的时候,你只需要继承这个类,然后重载相应的方法即可。

    使用SAX解析XML文件一般有以下五个步骤:
    1
    、创建一个SAXParserFactory对象;
    2
    、调用SAXParserFactory中的newSAXParser方法创建一个SAXParser对象;
    3
    、然后在调用SAXParser中的getXMLReader方法获取一个XMLReader对象;

    4、实例化一个DefaultHandler对象

    5、连接事件源对象XMLReader到事件处理类DefaultHandler

    6、调用XMLReaderparse方法从输入源中获取到的xml数据

    7、通过DefaultHandler返回我们需要的数据集合。

    我们仍然来解析上述那个天气预报的XML文件。

    编写代码如下:

    [java] view plaincopy
    1. mySAX.setOnClickListener(new Button.OnClickListener(){  
    2.             @Override  
    3.             public void onClick(View v) {    
    4.                 try{  
    5.                     String url = "http://www.google.com/ig/api?&weather=beijing";  
    6.                     DefaultHttpClient client = new DefaultHttpClient();   
    7.                     HttpUriRequest req = new HttpGet(url);   
    8.                     HttpResponse resp = client.execute(req);   
    9.                     HttpEntity ent = resp.getEntity();   
    10.                     InputStream stream = ent.getContent(); //将文件导入流,因此用InputStream  
    11.                       
    12.                     SAXParserFactory saxFactory = SAXParserFactory.newInstance();  //获取一个对象  
    13.                     SAXParser saxParser = saxFactory.newSAXParser();//利用获取到的对象创建一个解析器  
    14.                     XMLContentHandler handler = new XMLContentHandler();//设置defaultHandler  
    15.                     saxParser.parse(stream, handler);//进行解析  
    16.                     stream.close();//关闭流  
    17.                     /*XMLReader xmlReader = saxFactory.newSAXParser().getXMLReader();  //获取一个XMLReader 
    18.                     xmlReader.setContentHandler(handler);   
    19.                     xmlReader.parse(new InputSource(stream));  
    20.                     stream.close();*/  
    21.                 }catch(Exception e){  
    22.                      e.printStackTrace();  
    23.                 }  
    24.             }     
    25.         });  
    26.         }  
    27.     public class XMLContentHandler extends DefaultHandler {  
    28.         private static final String TAG = "XMLContentHandler";  
    29.   
    30.         @Override  
    31.         public void characters(char[] ch, int start, int length)  
    32.                 throws SAXException {  
    33.             Log.i(TAG, "解析内容:"+new String(ch,start,length));  
    34.         }  
    35.         @Override  
    36.         public void endDocument() throws SAXException {  
    37.             super.endDocument();  
    38.             Log.i(TAG, "文档解析完毕。");  
    39.         }  
    40.         @Override  
    41.         public void endElement(String uri, String localName, String qName)  
    42.                 throws SAXException {  
    43.             Log.i(TAG, localName+"解析完毕");  
    44.         }  
    45.         @Override  
    46.         public void startDocument() throws SAXException {  
    47.             Log.i(TAG, "开始解析... ...");  
    48.         }  
    49.         @Override  
    50.         public void startElement(String uri, String localName, String qName,  
    51.                 Attributes attributes) throws SAXException {  
    52.             Log.i(TAG, "解析元素:"+localName);  
    53.               
    54.             if(localName.equals("high")){  
    55.                 Log.i(TAG, "解析元素:"+localName);  
    56.                 i++;  
    57.                    if(i==2){  
    58.                        highestTmp.setText(String.valueOf((Integer.parseInt(attributes.getValue(0))-32)*5/9));                            
    59.                    }  
    60.             }  
    61.         }  
    62.     }  

    上面的那段注释:

    [java] view plaincopy
    1. /*XMLReader xmlReader =saxFactory.newSAXParser().getXMLReader(); //获取一个XMLReader 
    2.     xmlReader.setContentHandler(handler);  
    3. xmlReader.parse(newInputSource(stream)); 
    4. stream.close();*/  

    是用XMLReader来做解析的另外一种方法。效果是一样的。这里可以传流,也可以传一个字符串,如下所示:是传字符串。

    [java] view plaincopy
    1. xmlReader.parse(new InputSource(new StringReader(xmlStr)));  

    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
    1. <forecast_conditions>  
    2. <day_of_week data="周三"/>  
    3. <low data="22"/>  
    4. <high data="29"/>  
    5. <icon data="/ig/images/weather/chance_of_rain.gif"/>  
    6. <condition data="可能有雨"/>  
    7. </forecast_conditions>  

    这部分XML文件中day_of_week,low,high等是TAG,data是ATTRIBUTEA。当然,如果有<></>夹在开始和结束符号之间的部分,则为TXET。

    要想解析文档先要构建一个XmlPullParser对象。

    [java] view plaincopy
    1. final XmlPullParserFactory factory = XmlPullParserFactory.newInstance();   
    2. factory.setNamespaceAware(true);   
    3. final XmlPullParser parser = factory.newPullParser();   
    4. 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
    1. myPULL.setOnClickListener(new Button.OnClickListener(){  
    2.             @Override  
    3.             public void onClick(View v) {  
    4.                 try{  
    5.                     String url = "http://www.google.com/ig/api?&weather=beijing";  
    6.                     DefaultHttpClient client = new DefaultHttpClient();   
    7.                     HttpUriRequest req = new HttpGet(url);   
    8.                     HttpResponse resp = client.execute(req);   
    9.                     HttpEntity ent = resp.getEntity();   
    10.                       
    11.                     InputStream stream = ent.getContent(); //将文件导入流,因此用InputStream  
    12.                     XmlPullParserFactory factory = XmlPullParserFactory.newInstance();  
    13.                     factory.setNamespaceAware(true);  
    14.                     XmlPullParser xpp = factory.newPullParser();  
    15.                     xpp.setInput(stream, null);  
    16.                     //xpp.setInput( new StringReader ( "<foo>Hello World!</foo>" ) );  
    17.                     int eventType = xpp.getEventType();  
    18.                     while (eventType != XmlPullParser.END_DOCUMENT) {  
    19.                         if(eventType == XmlPullParser.START_DOCUMENT) {  
    20.                             System.out.println("Start document");  
    21.                         } else if(eventType == XmlPullParser.START_TAG) {  
    22.                             System.out.println("Start tag "+xpp.getName());  
    23.                             if(xpp.getName().equals("high")){  
    24.                                 j++;  
    25.                                 if(j==2){  
    26.                                     highestTmp.setText(String.valueOf((Integer.parseInt(xpp.getAttributeValue(0))-32)*5/9));                             
    27.                                 }  
    28.                             }  
    29.                         } else if(eventType == XmlPullParser.END_TAG) {  
    30.                             System.out.println("End tag "+xpp.getName());  
    31.                         } else if(eventType == XmlPullParser.TEXT) {  
    32.                             System.out.println("Text "+xpp.getText());  
    33.                         }  
    34.                         eventType = xpp.next();  
    35.                     }  
    36.                     System.out.println("End document");  
    37.                     }  
    38.                     catch(Exception e){  
    39.                         e.printStackTrace();  
    40.                     }  
    41.                 }     
    42.             });   

    小结一下,如果在一个XML文档中我们只需要前面一部分数据,但是使用SAX方式或DOM方式会对整个文档进行解析,尽管XML文档中后面的大部分数据我们其实都不需要解析,因此这样实际上就浪费了处理资源。使用PULL方式正合适。

    [java] view plaincopy
    1. //创建XmlPullParser,有两种方式     
    2.     //方式一:使用工厂类XmlPullParserFactory     
    3.     XmlPullParserFactory pullFactory = XmlPullParserFactory.newInstance();     
    4.     XmlPullParser xmlPullParser = pullFactory.newPullParser();     
    5.     //方式二:使用Android提供的实用工具类android.util.Xml    
    6.     XmlPullParser xmlPullParser = Xml.newPullParser();   

        XmlPullParser.setInput(InputStream inputStream, String inputEncoding) 解析对应的输入文件

        XmlPullParser.getEventType() 得到元素

        判断元素是否是START_DOCUMENT、END_DOCUMENT、START_TAG、END_TAG、TEXT中的哪种,进行相应解析。

    后附上三种方式整合在一起的代码:

    [java] view plaincopy
    1. <p>/*</p><p> *  Android开发之XML文件的解析</p><p> *  SimpleweatherActivity.java </p><p> * Created on: 2012-7-24</p><p> * Author: blueeagle</p><p> *  Email:liujiaxiang@gmail.com</p><p> */</p>  
    [java] view plaincopy
    1. public class SimpleweatherActivity extends Activity {  
    2.     /** Called when the activity is first created. */  
    3.     Button myDOM;  
    4.     Button mySAX;  
    5.     Button myPULL;  
    6.     XmlPullParser x;  
    7.     TextView highestTmp;  
    8.     int iHighestTmp;  
    9.     int i = 0;  
    10.     int j = 0;  
    11.     @Override  
    12.     public void onCreate(Bundle savedInstanceState) {  
    13.         super.onCreate(savedInstanceState);  
    14.         setContentView(R.layout.main);  
    15.         myDOM = (Button)findViewById(R.id.DOM);   
    16.         mySAX = (Button)findViewById(R.id.SAX);  
    17.         myPULL = (Button)findViewById(R.id.PULL);  
    18.         highestTmp = (TextView)findViewById(R.id.highestTmp);  
    19.           
    20.         myDOM.setOnClickListener(new Button.OnClickListener(){  
    21.   
    22.             @Override  
    23.             public void onClick(View v) {  
    24.                 try{  
    25.                 String url = "http://www.google.com/ig/api?&weather=beijing";  
    26.                 DefaultHttpClient client = new DefaultHttpClient();   
    27.                 HttpUriRequest req = new HttpGet(url);   
    28.                 HttpResponse resp = client.execute(req);   
    29.                 HttpEntity ent = resp.getEntity();   
    30.                 InputStream stream = ent.getContent();   
    31.                 DocumentBuilder myDocBuilder = DocumentBuilderFactory.newInstance().newDocumentBuilder();   
    32.                 Document myDoc = myDocBuilder.parse(new InputSource(stream));   
    33.                 //找到根Element  
    34.                 Element root=myDoc.getDocumentElement();  
    35.                 //找到子节点forecast_conditions  
    36.                 NodeList nodes=root.getElementsByTagName("forecast_conditions");  
    37.                 iHighestTmp = (Integer.parseInt(nodes.item(1).getChildNodes().item(2).getAttributes().item(0).getNodeValue())-32)*5/9;  
    38.                 highestTmp.setText(String.valueOf(iHighestTmp));  
    39.                 } catch (Exception e) {   
    40.                 e.printStackTrace();   
    41.                 }}  
    42.                 });   
    43.         mySAX.setOnClickListener(new Button.OnClickListener(){  
    44.             @Override  
    45.             public void onClick(View v) {    
    46.                 try{  
    47.                     String url = "http://www.google.com/ig/api?&weather=beijing";  
    48.                     DefaultHttpClient client = new DefaultHttpClient();   
    49.                     HttpUriRequest req = new HttpGet(url);   
    50.                     HttpResponse resp = client.execute(req);   
    51.                     HttpEntity ent = resp.getEntity();   
    52.                     InputStream stream = ent.getContent(); //将文件导入流,因此用InputStream  
    53.                       
    54.                     SAXParserFactory saxFactory = SAXParserFactory.newInstance();  //获取一个对象  
    55.                     SAXParser saxParser = saxFactory.newSAXParser();//利用获取到的对象创建一个解析器  
    56.                     XMLContentHandler handler = new XMLContentHandler();//设置defaultHandler  
    57.                     saxParser.parse(stream, handler);//进行解析  
    58.                     stream.close();//关闭流  
    59.                     /*XMLReader xmlReader = saxFactory.newSAXParser().getXMLReader();  //获取一个XMLReader 
    60.                     xmlReader.setContentHandler(handler);   
    61.                     xmlReader.parse(new InputSource(stream));  
    62.                     stream.close();*/  
    63.                 }catch(Exception e){  
    64.                      e.printStackTrace();  
    65.                 }  
    66.             }     
    67.         });  
    68.         myPULL.setOnClickListener(new Button.OnClickListener(){  
    69.             @Override  
    70.             public void onClick(View v) {  
    71.                 try{  
    72.                     String url = "http://www.google.com/ig/api?&weather=beijing";  
    73.                     DefaultHttpClient client = new DefaultHttpClient();   
    74.                     HttpUriRequest req = new HttpGet(url);   
    75.                     HttpResponse resp = client.execute(req);   
    76.                     HttpEntity ent = resp.getEntity();   
    77.                       
    78.                     InputStream stream = ent.getContent(); //将文件导入流,因此用InputStream  
    79.                     XmlPullParserFactory factory = XmlPullParserFactory.newInstance();  
    80.                     factory.setNamespaceAware(true);  
    81.                     XmlPullParser xpp = factory.newPullParser();  
    82.                     xpp.setInput(stream, null);  
    83.                     //xpp.setInput( new StringReader ( "<foo>Hello World!</foo>" ) );  
    84.                     int eventType = xpp.getEventType();  
    85.                     while (eventType != XmlPullParser.END_DOCUMENT) {  
    86.                         if(eventType == XmlPullParser.START_DOCUMENT) {  
    87.                             System.out.println("Start document");  
    88.                         } else if(eventType == XmlPullParser.START_TAG) {  
    89.                             System.out.println("Start tag "+xpp.getName());  
    90.                             if(xpp.getName().equals("high")){  
    91.                                 j++;  
    92.                                 if(j==2){  
    93.                                     highestTmp.setText(String.valueOf((Integer.parseInt(xpp.getAttributeValue(0))-32)*5/9));                             
    94.                                 }  
    95.                             }  
    96.                         } else if(eventType == XmlPullParser.END_TAG) {  
    97.                             System.out.println("End tag "+xpp.getName());  
    98.                         } else if(eventType == XmlPullParser.TEXT) {  
    99.                             System.out.println("Text "+xpp.getText());  
    100.                         }  
    101.                         eventType = xpp.next();  
    102.                     }  
    103.                     System.out.println("End document");  
    104.                     }  
    105.                     catch(Exception e){  
    106.                         e.printStackTrace();  
    107.                     }  
    108.                 }     
    109.             });       
    110.         }  
    111.     public class XMLContentHandler extends DefaultHandler {  
    112.         private static final String TAG = "XMLContentHandler";  
    113.   
    114.         @Override  
    115.         public void characters(char[] ch, int start, int length)  
    116.                 throws SAXException {  
    117.             Log.i(TAG, "解析内容:"+new String(ch,start,length));  
    118.         }  
    119.         @Override  
    120.         public void endDocument() throws SAXException {  
    121.             super.endDocument();  
    122.             Log.i(TAG, "文档解析完毕。");  
    123.         }  
    124.         @Override  
    125.         public void endElement(String uri, String localName, String qName)  
    126.                 throws SAXException {  
    127.             Log.i(TAG, localName+"解析完毕");  
    128.         }  
    129.         @Override  
    130.         public void startDocument() throws SAXException {  
    131.             Log.i(TAG, "开始解析... ...");  
    132.         }  
    133.         @Override  
    134.         public void startElement(String uri, String localName, String qName,  
    135.                 Attributes attributes) throws SAXException {  
    136.             Log.i(TAG, "解析元素:"+localName);  
    137.               
    138.             if(localName.equals("high")){  
    139.                 Log.i(TAG, "解析元素:"+localName);  
    140.                 i++;  
    141.                    if(i==2){  
    142.                        highestTmp.setText(String.valueOf((Integer.parseInt(attributes.getValue(0))-32)*5/9));                            
    143.                    }  
    144.             }  
    145.         }  
    146.     }  
    147. }  
    当点击三种方式的任何一个按钮时,均能够得到相同的结果。
  • 相关阅读:
    OS模块功能
    read()、readline()、readlines()区别
    【ML-0-2】矩阵求导-定义法和微分法
    【ML-0-1】矩阵求导-定义和求导布局
    博客园转文章的方法
    风格迁移论文--Arbitrary style transfer in real-time with adaptive instance normalization
    【TF-3-2】Tensorflow-mnist的手写识别
    【TF-3-1】Tensorflow--简单线性拟合
    图像分割简介
    图像表示与图像处理的基本概念
  • 原文地址:https://www.cnblogs.com/walccott/p/4957579.html
Copyright © 2020-2023  润新知