安卓xml解析
来源:互联网 发布:telnet udp 连接端口 编辑:程序博客网 时间:2024/05/14 09:55
在Android平台下几种常见的XML解析方法。分别为SAX解析器、DOM解析器和PULL解析器.
SAX解析器:SAX(Simple API for XML)解析器是一种基于事件的解析器,它的核心是事件处理模式,主要是围绕着事件源以及事件处理器来工作的。当事件源产生事件后,调用事件处理器相应的处理方法,一个事件就可以得到处理。在事件源调用事件处理器中特定方法的时候,还要传递给事件处理器相应事件的状态信息,这样事件处理器才能够根据提供的事件信息来决定自己的行为。SAX解析器的优点是解析速度快,占用内存少.
DOM解析器:DOM是基于树形结构的的节点或信息片段的集合,允许开发人员使用DOM API遍历XML树、检索所需数据。分析该结构通常需要加载整个文档和构造树形结构,然后才可以检索和更新节点信息。由于DOM在内存中以树形结构存放,因此检索和更新效率会更高。但是对于特别大的文档,解析和加载整个文档将会很耗资源。
PULL解析器:PULL解析器的运行方式和SAX类似,都是基于事件的模式。不同的是,在PULL解析过程中,我们需要自己获取产生的事件然后做相应的操作,而不像SAX那样由处理器触发一种事件的方法,执行我们的代码。PULL解析器小巧轻便,解析速度快,简单易用,非常适合在Android移动设备中使用,Android系统内部在解析各种XML时也是用PULL解析器。
SAX解析器:SAX(Simple API for XML)解析器是一种基于事件的解析器,它的核心是事件处理模式,主要是围绕着事件源以及事件处理器来工作的。当事件源产生事件后,调用事件处理器相应的处理方法,一个事件就可以得到处理。在事件源调用事件处理器中特定方法的时候,还要传递给事件处理器相应事件的状态信息,这样事件处理器才能够根据提供的事件信息来决定自己的行为。SAX解析器的优点是解析速度快,占用内存少.
DOM解析器:DOM是基于树形结构的的节点或信息片段的集合,允许开发人员使用DOM API遍历XML树、检索所需数据。分析该结构通常需要加载整个文档和构造树形结构,然后才可以检索和更新节点信息。由于DOM在内存中以树形结构存放,因此检索和更新效率会更高。但是对于特别大的文档,解析和加载整个文档将会很耗资源。
PULL解析器:PULL解析器的运行方式和SAX类似,都是基于事件的模式。不同的是,在PULL解析过程中,我们需要自己获取产生的事件然后做相应的操作,而不像SAX那样由处理器触发一种事件的方法,执行我们的代码。PULL解析器小巧轻便,解析速度快,简单易用,非常适合在Android移动设备中使用,Android系统内部在解析各种XML时也是用PULL解析器。
其中sax,pull都是基于流的模式,不支持随机访问,只有dom解析器支持.本文只要pull解析方式,其他两种请自行查阅资料.
一生成xml文件
方式一:利用拼接字符串的方式
//在内存中把xml备份短信的格式拼接出来StringBuffer sb = new StringBuffer();sb.append("<?xml version='1.0' encoding='utf-8' standalone='yes' ?>");sb.append("<messages>");for (Message sms : smsList) {sb.append("<sms>");sb.append("<body>");sb.append(sms.getBody());sb.append("</body>");sb.append("<date>");sb.append(sms.getDate());sb.append("</date>");sb.append("<type>");sb.append(sms.getType());sb.append("</type>");sb.append("<address>");sb.append(sms.getAddress());sb.append("</address>");sb.append("</sms>");}sb.append("</messages>");File file = new File("sdcard/sms.xml");try {FileOutputStream fos = new FileOutputStream(file);fos.write(sb.toString().getBytes());fos.close();} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}方式二:利用XmlSerializer序列化器生成xml.
//使用xml序列化器生成xml文件//1.拿到序列化器对象XmlSerializer xs = Xml.newSerializer();//2.初始化File file = new File("sdcard/sms2.xml");try {FileOutputStream fos = new FileOutputStream(file);//enconding:指定用什么编码生成xml文件xs.setOutput(fos, "utf-8");//3.开始生成xml文件//enconding:指定头结点中的enconding属性的值xs.startDocument("utf-8", true);xs.startTag(null, "message");for (Message sms : smsList) {xs.startTag(null, "sms");xs.startTag(null, "body");xs.text(sms.getBody() + "<body>");xs.endTag(null, "body");xs.startTag(null, "date");xs.text(sms.getDate());xs.endTag(null, "date");xs.startTag(null, "type");xs.text(sms.getType());xs.endTag(null, "type");xs.startTag(null, "address");xs.text(sms.getAddress());xs.endTag(null, "address");xs.endTag(null, "sms");}xs.endTag(null, "message");//告诉序列化器,文件生成完毕xs.endDocument();} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}
二 pull 解析器解析
1.如下的xml文档要解析
<?xml version='1.0' encoding='utf-8' standalone='yes' ?><weather><city><name>上海</name><temp>5°</temp><pm>80</pm></city><city><name>北京</name><temp>-5°</temp><pm>800</pm></city><city><name>西安</name><temp>12°</temp><pm>60</pm></city></weather>2.javabean如下:
public class City {private String name;private String temp;private String pm;public String getName() {return name;}public void setName(String name) {this.name = name;}public String getTemp() {return temp;}public void setTemp(String temp) {this.temp = temp;}public String getPm() {return pm;}public void setPm(String pm) {this.pm = pm;}@Overridepublic String toString() {return "City [name=" + name + ", temp=" + temp + ", pm=" + pm + "]";}}3.开始解析
//获取到src文件夹下的资源文件InputStream is = getClassLoader().getResourceAsStream("weather.xml");//拿到pull解析器对象XmlPullParser xp = Xml.newPullParser();//初始化try {xp.setInput(is, "gbk");//获取当前节点的事件类型,通过事件类型的判断,我们可以知道当前节点是什么节点,从而确定我们应该做什么操作int type = xp.getEventType();City city = null;while(type != XmlPullParser.END_DOCUMENT){//根据节点的类型,要做不同的操作switch (type) {case XmlPullParser.START_TAG://获取当前节点的名字if("weather".equals(xp.getName())){//创建city集合对象,用于存放city的javabeancityList = new ArrayList<City>();}else if("city".equals(xp.getName())){//创建city的javabean对象city = new City();}else if("name".equals(xp.getName())){//获取当前节点的下一个节点的文本String name =xp.nextText();city.setName(name);}else if("temp".equals(xp.getName())){//获取当前节点的下一个节点的文本String temp = xp.nextText();city.setTemp(temp);}else if("pm".equals(xp.getName())){//获取当前节点的下一个节点的文本String pm = xp.nextText();city.setPm(pm);}break;case XmlPullParser.END_TAG:if("city".equals(xp.getName())){//把city的javabean放入集合中cityList.add(city);}break;}//把指针移动到下一个节点,并返回该节点的事件类型type = xp.next();}for (City c : cityList) {System.out.println(c.toString());}} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}
阅读全文
0 0
- 安卓xml解析
- 解析 xml 安卓
- 安卓 解析xml
- 安卓xml解析
- 安卓sax解析xml
- 安卓xml pull 解析
- 安卓笔记 xml解析
- 安卓中的XML解析
- 安卓SAX解析XML文件
- 安卓快速解析xml工具类
- 安卓解析xml格式字符串
- 安卓设备PULL解析XML文件
- XML解析和安卓单元测试框架
- 6.安卓pull解析XML文件
- 安卓网络访问解析XML
- 安卓 三种方式解析xml
- 安卓style.xml与attrs.xml的深入解析
- 安卓使用pull解析器解析xml
- 北大学霸:高考有漏洞可钻,学会套路,立马提分,屡试不爽!
- 浅析PageRank算法
- Android多渠道打包没你想的那么复杂
- Swarm 如何实现 Failover?- 每天5分钟玩转 Docker 容器技术(98)
- 六度空间
- 安卓xml解析
- 汇总网站内部的seo优化教程细节
- KYLIN生产环境配置
- 从群论角度理解欧拉公式
- 肖仰华 | 知识图谱研究的回顾与展望
- 收割屌丝玩法 强势的思维方式
- Java核心思想---------------一切皆对象
- 研究生手册(一)---论文篇
- Java中instanceof运算符用法详解