ImageVerifierCode 换一换
格式:DOCX , 页数:18 ,大小:24.33KB ,
资源ID:6711758      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/6711758.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(Android开发之XML文件的解析的三种方法.docx)为本站会员(b****6)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

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

1、Android开发之XML文件的解析的三种方法 Android开发之XML文件的解析的三种方法/* Android开发之XML文件的解析的三种方法*Created on: 2012-7-24*Author: blueeagle* Email:liujiaxiang*/本文主要讲解Android开发中如何对XML文件的解析,由于XML文件具有与平台无关,广泛应用于数据通信中,因此解析XML文件就显得很有意义。Android对XML文件解析的方法主要有3种。通常有三种方式:DOM、SAX和PULL,下面就分别针对这三种方式来进行讨论。假设我们在开发天气预报应用程序的时候,使用google给我们提供

2、的API,以及天气预报数据,例如我们要获得北京当前的天气预报数据,即可在浏览器中输入如下地址: 则可以看到一个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 modul

3、e_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=""/><lo

4、ngitude_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

5、="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="周二&

6、quot;/><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"/&

7、gt;<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"/

8、><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/

9、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文件很大的时候,处理效

10、率就会变得比较低,这也是DOM方式的一个缺点。现在我们来解析上文中提到的有关天气预报信息相关的xml文件。什么是解析呢?说的通俗一点,就是将这个带标签的XML文件识别出来,并抽取一些相关的,对我们有用的信息来给我们使用。那在这个文件里,时间,天气,温度,以及图标对我们来说是需要得到的。我们要对其做解析。解析的具体思路是:1.将XML文件加载进来。2.获取文档的根节点3.获取文档根节点中所有子节点的列表4.获取子节点列表中需要读取的节点信息根据这4个步骤,我们进行开发:首先就是如何加载XML文件,假设此文件来源于网络。String url = "DefaultHttpClient cl

11、ient = 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 = myDocBu

12、ilder.parse(new InputSource(stream);首先创建一个DocumentBuilderFactory实例然后加载XML文档(Document)加载完毕以后,就要进行节点获取操作,即第二步和第三步的操作:/找到根ElementElement root=document.getDocumentElement();/找到子节点forecast_conditionsNodeList nodes=root.getElementsByTagName(forecast_conditions);假设我需要获得该XML文件中周三的最高气温,则可以用下列代码得到:nodes.item(

13、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方式SAX是Simple API for XML的缩写。是一

14、个包也可以看成是一些接口。相比于DOM而言SAX是一种速度更快,更有效,占用内存更少的解析XML文件的方法。它是逐行扫描,可以做到边扫描边解析,因此SAX可以在解析文档的任意时刻停止解析。非常适用于Android等移动设备。SAX是基于事件驱动的。所谓事件驱动就是说,它不用解析完整个文档,在按内容顺序解析文档过程中,SAX会判断当前读到的字符是否符合XML文件语法中的某部分。如果符合某部分,则会触发事件。所谓触发事件,就是调用一些回调方法。当然android的事件机制是基于回调方法的,在用SAX解析xml文档时候,在读取到文档开始和结束标签时候就会回调一个事件,在读取到其他节点与内容时候也会回

15、调一个事件。在SAX接口中,事件源是org.xml.sax包中的XMLReader,它通过parser()方法来解析XML文档,并产生事件。事件处理器是org.xml.sax包中ContentHander、DTDHander、ErrorHandler,以及EntityResolver这4个接口。这四个接口的详细说明如下:事件处理器名称事件处理器处理的事件XMLReader注册方法ContentHanderXML文档的开始与结束,XML文档标签的开始与结束,接收字符数据,跳过实体,接收元素内容中可忽略的空白等。setContentHandler(ContentHandler h)DTDHande

16、r处理DTD解析时产生的相应事件setDTDHandler(DTDHandler h)ErrorHandler处理XML文档时产生的错误setErrorHandler(ErrorHandler h)EntityResolver处理外部实体setEntityResolver(EntityResolver e)我们用来做内容解析的回调方法一般都定义在ContentHandler接口中。ContentHandler接口常用的方法:startDocument() 当遇到文档的开头的时候,调用这个方法,可以在其中做一些预处理的工作。endDocument() 当文档结束的时候,调用这个方法,可以在其中做

17、一些善后的工作。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,

18、 int length) 这个方法用来处理在XML文件中读到的内容。例如:<highdata="30"/>主要目的是获取high标签中的值。第一个参数用于存放文件的内容,后面两个参数是读到的字符串在这个数组中的起始位置和长度,使用new String(ch,start,length)就可以获取内容。注意:SAX的一个重要特点就是它的流式处理,当遇到一个标签的时候,它并不会纪录下之前所碰到的标签,即在startElement()方法中,所有能够知道的信息,就是标签的名字和属性,至于标签的嵌套结构,上层标签的名字,是否有子元属等等其它与结构相关的信息,

19、都是不知道的,都需要你的程序来完成。这使得SAX在编程处理上没有DOM方便。现在我们截取一段XML文件来做解析,其调用方法是这样的:<?xml version="1.0"?> -> startDocument()<weather> -> startElement<forecast_information> -> startElement<city> -> startElementbeijing -> characters</city> -> endElement</fore

20、cast_information > -> endElement</weather > -> startElement文档结束 -> startDocument()SAX的解析步骤:首先需要注意的是:SAX还为其制定了一个Helper类:DefaultHandler它实现了ContentHandler这个接口,但是其所有的方法体都为空,在实现的时候,你只需要继承这个类,然后重载相应的方法即可。使用SAX解析XML文件一般有以下五个步骤:1、创建一个SAXParserFactory对象;2、调用SAXParserFactory中的newSAXParser方法创

21、建一个SAXParser对象;3、然后在调用SAXParser中的getXMLReader方法获取一个XMLReader对象;4、实例化一个DefaultHandler对象5、连接事件源对象XMLReader到事件处理类DefaultHandler中6、调用XMLReader的parse方法从输入源中获取到的xml数据7、通过DefaultHandler返回我们需要的数据集合。我们仍然来解析上述那个天气预报的XML文件。编写代码如下:mySAX.setOnClickListener(new Button.OnClickListener() Override public void onClic

22、k(View v) try String url = " 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 = SAXPars

23、erFactory.newInstance(); /获取一个对象 SAXParser saxParser = saxFactory.newSAXParser();/利用获取到的对象创建一个解析器 XMLContentHandler handler = new XMLContentHandler();/设置defaultHandler saxParser.parse(stream, handler);/进行解析 stream.close();/关闭流 /*XMLReader xmlReader = saxFactory.newSAXParser().getXMLReader(); /获取一个XM

24、LReader 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(ch

25、ar 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

26、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, "解析元素:"+localNa

27、me); 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(han

28、dler); xmlReader.parse(newInputSource(stream); stream.close();*/是用XMLReader来做解析的另外一种方法。效果是一样的。这里可以传流,也可以传一个字符串,如下所示:是传字符串。xmlReader.parse(new InputSource(new StringReader(xmlStr);PULL方式除了可以使用 SAX和DOM解析XML文件,也可以使用Android内置的Pull解析器解析XML文件。 Pull解析器的运行方式与 SAX 解析器相似。它也是事件触发的。Pull解析方式让应用程序完全控制文档该怎么

29、样被解析。比如开始和结束元素事件,使用parser.next()可以进入下一个元素并触发相应事件。通过Parser.getEventType()方法来取得事件的代码值,解析是在开始时就完成了大部分处理。事件将作为数值代码被发送,因此可以使用一个switch对感兴趣的事件进行处理。Pull解析是一个遍历文档的过程,每次调用next(),nextTag(), nextToken()和nextText()都会向前推进文档,并使Parser停留在某些事件上面,但是不能倒退。然后把文档设置给Parser。Android中对Pull方法提供了支持的API,主要是org.xmlp

30、ull.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=&q

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1