安卓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,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();}







原创粉丝点击