`
yunlonglove
  • 浏览: 238978 次
社区版块
存档分类
最新评论

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

 
阅读更多


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

/*

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

*

*Created on: 2012-7-24

*Author: blueeagle

* Email:liujiaxiang@gmail.com

*/

本文主要讲解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文件没有任何样式信息,只有文档结构树的显示。

文件内容如下所示:

<xml_api_reply version="1">
<weather module_id="0" tab_id="0" mobile_row="0" mobile_zipped="1" row="0" section="0">
<forecast_information>
<city data="Beijing, Beijing"/>
<postal_code data="beijing"/>
<latitude_e6 data=""/>
<longitude_e6 data=""/>
<forecast_date data="2012-07-24"/>
<current_date_time data="2012-07-24 15:30:00 +0000"/>
<unit_system data="SI"/>
</forecast_information>
<current_conditions>
<condition data="多云"/>
<temp_f data="77"/>
<temp_c data="25"/>
<humidity data="湿度: 78%"/>
<icon data="/ig/images/weather/cn_cloudy.gif"/>
<wind_condition data="风向: 东北、风速:2 米/秒"/>
</current_conditions>
<forecast_conditions>
<day_of_week data="周二"/>
<low data="22"/>
<high data="30"/>
<icon data="/ig/images/weather/cn_cloudy.gif"/>
<condition data="多云"/>
</forecast_conditions>
<forecast_conditions>
<day_of_week data="周三"/>
<low data="24"/>
<high data="30"/>
<icon data="/ig/images/weather/chance_of_rain.gif"/>
<condition data="可能有雨"/>
</forecast_conditions>
<forecast_conditions>
<day_of_week data="周四"/>
<low data="25"/>
<high data="29"/>
<icon data="/ig/images/weather/thunderstorm.gif"/>
<condition data="雷阵雨"/>
</forecast_conditions>
<forecast_conditions>
<day_of_week data="周五"/>
<low data="24"/>
<high data="31"/>
<icon data="/ig/images/weather/chance_of_storm.gif"/>
<condition data="可能有暴风雨"/>
</forecast_conditions>
</weather>
</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文件,假设此文件来源于网络。

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(); 
DocumentBuilder myDocBuilder = DocumentBuilderFactory.newInstance().newDocumentBuilder(); 
Document myDoc = myDocBuilder.parse(new InputSource(stream));

首先创建一个DocumentBuilderFactory实例

然后加载XML文档(Document

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

//找到根Element
Element root=document.getDocumentElement();
//找到子节点forecast_conditions
NodeList nodes=root.getElementsByTagName(forecast_conditions);
假设我需要获得该XML文件中周三的最高气温,则可以用下列代码得到:
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文件中读到的内容。例如:<highdata="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 > ----------> startElement

文档结束 ----------> 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文件。

编写代码如下:

mySAX.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
    			    
                    SAXParserFactory saxFactory = SAXParserFactory.newInstance();  //获取一个对象
                    SAXParser saxParser = saxFactory.newSAXParser();//利用获取到的对象创建一个解析器
    				XMLContentHandler handler = new XMLContentHandler();//设置defaultHandler
    				saxParser.parse(stream, handler);//进行解析
    				stream.close();//关闭流
    				/*XMLReader xmlReader = saxFactory.newSAXParser().getXMLReader();  //获取一个XMLReader
                    xmlReader.setContentHandler(handler);  
    				xmlReader.parse(new InputSource(stream)); 
    				stream.close();*/
                }catch(Exception e){
                	 e.printStackTrace();
                }
			}	
        });
        }
    public class XMLContentHandler extends DefaultHandler {
    	private static final String TAG = "XMLContentHandler";

    	@Override
    	public void characters(char[] ch, int start, int length)
    			throws SAXException {
    		Log.i(TAG, "解析内容:"+new String(ch,start,length));
    	}
    	@Override
    	public void endDocument() throws SAXException {
    		super.endDocument();
    		Log.i(TAG, "文档解析完毕。");
    	}
    	@Override
    	public void endElement(String uri, String localName, String qName)
    			throws SAXException {
    		Log.i(TAG, localName+"解析完毕");
    	}
    	@Override
    	public void startDocument() throws SAXException {
    		Log.i(TAG, "开始解析... ...");
    	}
    	@Override
    	public void startElement(String uri, String localName, String qName,
    			Attributes attributes) throws SAXException {
    		Log.i(TAG, "解析元素:"+localName);
    		
            if(localName.equals("high")){
            	Log.i(TAG, "解析元素:"+localName);
            	i++;
                   if(i==2){
                	   highestTmp.setText(String.valueOf((Integer.parseInt(attributes.getValue(0))-32)*5/9));                		   
                   }
            }
    	}
    }

上面的那段注释:

               /*XMLReader xmlReader =saxFactory.newSAXParser().getXMLReader(); //获取一个XMLReader
                   xmlReader.setContentHandler(handler); 
               xmlReader.parse(newInputSource(stream));
               stream.close();*/

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

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文件是:

<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对象。

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上。

核心代码如下所示:
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();
					}
				}  	
        	}); 

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

//创建XmlPullParser,有两种方式   
    //方式一:使用工厂类XmlPullParserFactory   
    XmlPullParserFactory pullFactory = XmlPullParserFactory.newInstance();   
    XmlPullParser xmlPullParser = pullFactory.newPullParser();   
    //方式二:使用Android提供的实用工具类android.util.Xml  
    XmlPullParser xmlPullParser = Xml.newPullParser(); 

<wbr><wbr><wbr><a href=""><span style="color:windowtext">XmlPullParser</span></a>.setInput(<a href=""><span style="color:windowtext">InputStream</span></a>inputStream,<a href=""><span style="color:windowtext">String</span></a>inputEncoding)<wbr>解析对应的输入文件</wbr></wbr></wbr></wbr>

<wbr><wbr><wbr><a href=""><span style="color:windowtext">XmlPullParser</span></a>.getEventType()<wbr>得到元素</wbr></wbr></wbr></wbr>

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

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

/*

* Android开发之XML文件的解析

* SimpleweatherActivity.java

*Created on: 2012-7-24

*Author: blueeagle

* Email:liujiaxiang@gmail.com

*/

public class SimpleweatherActivity extends Activity {
    /** Called when the activity is first created. */
	Button myDOM;
	Button mySAX;
	Button myPULL;
	XmlPullParser x;
	TextView highestTmp;
	int iHighestTmp;
	int i = 0;
	int j = 0;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        myDOM = (Button)findViewById(R.id.DOM); 
        mySAX = (Button)findViewById(R.id.SAX);
        myPULL = (Button)findViewById(R.id.PULL);
        highestTmp = (TextView)findViewById(R.id.highestTmp);
        
        myDOM.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(); 
			    DocumentBuilder myDocBuilder = DocumentBuilderFactory.newInstance().newDocumentBuilder(); 
			    Document myDoc = myDocBuilder.parse(new InputSource(stream)); 
			    //找到根Element
			    Element root=myDoc.getDocumentElement();
			    //找到子节点forecast_conditions
			    NodeList nodes=root.getElementsByTagName("forecast_conditions");
			    iHighestTmp = (Integer.parseInt(nodes.item(1).getChildNodes().item(2).getAttributes().item(0).getNodeValue())-32)*5/9;
			    highestTmp.setText(String.valueOf(iHighestTmp));
			    } catch (Exception e) { 
			    e.printStackTrace(); 
			    }}
			    }); 
        mySAX.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
    			    
                    SAXParserFactory saxFactory = SAXParserFactory.newInstance();  //获取一个对象
                    SAXParser saxParser = saxFactory.newSAXParser();//利用获取到的对象创建一个解析器
    				XMLContentHandler handler = new XMLContentHandler();//设置defaultHandler
    				saxParser.parse(stream, handler);//进行解析
    				stream.close();//关闭流
    				/*XMLReader xmlReader = saxFactory.newSAXParser().getXMLReader();  //获取一个XMLReader
                    xmlReader.setContentHandler(handler);  
    				xmlReader.parse(new InputSource(stream)); 
    				stream.close();*/
                }catch(Exception e){
                	 e.printStackTrace();
                }
			}	
        });
        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();
					}
				}  	
        	});     
        }
    public class XMLContentHandler extends DefaultHandler {
    	private static final String TAG = "XMLContentHandler";

    	@Override
    	public void characters(char[] ch, int start, int length)
    			throws SAXException {
    		Log.i(TAG, "解析内容:"+new String(ch,start,length));
    	}
    	@Override
    	public void endDocument() throws SAXException {
    		super.endDocument();
    		Log.i(TAG, "文档解析完毕。");
    	}
    	@Override
    	public void endElement(String uri, String localName, String qName)
    			throws SAXException {
    		Log.i(TAG, localName+"解析完毕");
    	}
    	@Override
    	public void startDocument() throws SAXException {
    		Log.i(TAG, "开始解析... ...");
    	}
    	@Override
    	public void startElement(String uri, String localName, String qName,
    			Attributes attributes) throws SAXException {
    		Log.i(TAG, "解析元素:"+localName);
    		
            if(localName.equals("high")){
            	Log.i(TAG, "解析元素:"+localName);
            	i++;
                   if(i==2){
                	   highestTmp.setText(String.valueOf((Integer.parseInt(attributes.getValue(0))-32)*5/9));                		   
                   }
            }
    	}
    }
}
当点击三种方式的任何一个按钮时,均能够得到相同的结果。



分享到:
评论

相关推荐

    Android开发之XML文件解析的使用

    在Android开发中,XML文件解析是一项重要的技能,用于读取和操作XML数据。XML(Extensible Markup Language)是一种结构化数据格式,常用于存储和传输数据。本篇文章将重点讲解如何在Android中使用SAX(Simple API ...

    android下解析xml文件的demo

    在Android开发中,XML文件常用于存储数据、配置文件或者作为接口返回的数据格式。本教程将详细介绍如何在Android环境下解析XML文件,以"ReadXMLDemo"为例,展示具体步骤和关键知识点。 首先,XML(eXtensible ...

    Android 解析 XML 三种方法

    SAX是一种基于事件驱动的解析方式,它逐行读取XML文件,当遇到标签开始、结束、文本内容等事件时,会触发相应的回调函数。这种方式适合处理大型XML文档,因为它不需要一次性加载整个文件到内存中,可以节省资源。...

    android开发之xml文件操作——xml创建和pull解析xml

    在Android开发中,XML文件操作是一项基础且重要的技能,它涉及到资源管理、数据持久化以及配置文件等多个方面。本项目主要关注的是XML的创建和使用Pull解析器来解析XML,这是Android系统中处理XML数据的一种高效方法...

    android xml pull解析示例

    XML(eXtensible Markup Language)是一种用于标记数据的语言,广泛应用于Android开发中,用于存储配置、布局等信息。在Android系统中,XML Pull解析是一种轻量级且高效的解析XML文档的方法,它允许应用程序按需读取...

    老罗Android视频开发教程 android解析xml文件代码

    通过老罗的Android视频教程,开发者可以学习到如何有效地解析XML文件,提升在Android开发中的数据处理能力。不论是DOM、SAX还是Pull解析,每种方法都有其适用场景,理解并熟练掌握这些技术,将对Android应用开发...

    android 三种xml解析方式整合

    在Android开发中,XML(eXtensible Markup Language)是一种常用的数据存储和交换格式,用于配置文件、数据传输等场景。对于XML的处理,Android提供了三种主要的解析方式:DOM(Document Object Model)、SAX...

    android XML三种解析及生成

    本文将深入探讨Android中的三种XML解析方式:SAX(Simple API for XML)、Pull Parser和DOM(Document Object Model),以及如何生成XML文件。 ### 1. SAX解析 SAX解析器是基于事件驱动的解析模型,它逐行读取XML...

    android 解析XML文件 生成XML文件

    在Android开发中,XML文件广泛用于存储数据、配置文件以及应用程序间的数据交换。本文将深入探讨如何使用SAX、DOM和Pull解析器解析XML文件,以及如何生成XML文件。我们将同时展示Java和Kotlin两种语言的实现方法。 ...

    android中xml文件的解析.doc

    理解如何解析XML文件是至关重要的,本节将深入探讨Android中的三种XML解析方法:SAX、DOM和Pull解析。 **SAX解析** SAX(Simple API for XML)是一种基于事件驱动的解析方式,它不加载整个XML文档到内存,而是逐行...

    android XML解析的三种方法源代码

    在Android开发中,XML是一种广泛使用的数据格式,用于存储和传输结构化数据。XML解析是将XML文档转换为可操作的数据的关键步骤。本教程将深入探讨Android中的三种主要XML解析方法:SAX(Simple API for XML)、Pull...

    Android 解析xml文件

    在Android开发中,XML文件常用于存储数据、配置或布局信息。XML(eXtensible Markup Language)是一种结构化标记语言,易于阅读和编写,同时机器也能方便地解析和生成。本篇将深入探讨Android中解析XML文件的方法,...

    android的xml文件的解析

    在Android开发中,XML文件广泛用于布局设计、配置设置、数据存储等方面,因此理解XML文件的解析至关重要。本文将深入探讨两种主要的XML解析方法:DOM解析和SAX解析。 一、XML概述 XML(eXtensible Markup Language...

    在android中使用pull解析xml文件

    在Android开发中,XML文件常用于存储数据,如配置文件、布局文件等。Pull解析器是一种轻量级的解析方式,适用于处理XML流,尤其在内存有限的移动设备上更为适用。本文将深入探讨如何在Android中使用Pull解析器解析...

    android解析xml的4种方法

    XML(eXtensible Markup Language)是一种用于标记数据的语言,广泛应用于Android开发中,用于存储和传输数据。本文将深入探讨在Android环境中解析XML的四种主要方法:DOM、SAX、Pull Parser以及XMLPullParser。 1....

    六,Android Xml解析

    这篇博文将深入探讨Android中的XML解析机制,包括DOM、SAX和Pull解析器三种主要方法。 首先,我们来看DOM解析。DOM(Document Object Model)是一种将XML文档加载到内存中并创建一个树形结构的方法。通过DOM解析,...

    android Dom解析xml文件

    在Android开发中,XML文件广泛用于存储数据、配置和布局信息。DOM(Document Object Model)解析是处理XML文件的一种常用方法。DOM解析器将整个XML文档加载到内存中,形成一个树形结构,允许开发者通过节点操作来...

    [Android实例] Android之解析XML文件

    在Android开发中,解析XML文件是一项常见的需求。本文将详细介绍如何使用SAX(Simple API for XML)解析器来解析XML文件,并通过一个具体的实例来进行说明。 #### 二、SAX解析器简介 SAX是一种基于事件驱动的XML...

    android 之xml解析大全

    DOM将整个XML文件解析成一个树形结构,每个节点代表XML文档的一部分。Document对象是这棵树的根,可以遍历和修改整个文档。这种方式易于操作,但不适合大文件,因为会一次性加载整个XML到内存。在小规模数据处理和...

    Android Dom解析XML

    在Android开发中,XML文件常用于存储数据或配置信息,如布局文件、资源文件等。本文将深入探讨如何使用DOM(Document Object Model)解析XML在Android应用中的实践。DOM解析方式允许开发者一次性加载整个XML文档到...

Global site tag (gtag.js) - Google Analytics