android操作XML的几种方式(转)
XML作为一种业界公认的数据交换格式,在各个平台与语言之上,都有广泛使用和实现。其标准型,可靠性,安全性......毋庸置疑。在android平台上,我们要想实现数据存储和数据交换,经常会使用到xml数据格式和xml文件。
小提示:android中存储数据一般有如下几种:SharedPreferences(参数化),XML文件,sqllite数据库,网络,ContentProvider(内容提供者)等。
在android中,操作xml文件,一般有几种方式:SAX操作,Pull操作,DOM操作等。其中DOM的方式,可能是大家最熟悉的,也是符合W3C标准的。
1)
在java平台中,有诸如DOM4J这样优秀的开源包,极大程度的方便大家使用DOM标准来操作XML文件。在javascript中,不同的浏览器解析引擎,对DOM的解析和操作也略有差异(不过这不是本章介绍的重点)。而DOM的方式,也有其缺点。通常一次性加载xml文件,再使用DOM的 api去进行解析,这样很大程度的消耗内存,对性能会有一定影响。而我们的android手机,虽然配置在不断的升级,但是内存方面,暂时还无法与传统的PC去媲美。所以,在android上面,不太推荐使用DOM的方式来解析和操作XML。
- package cn.itcast.service;
- import java.io.InputStream;
- import java.util.ArrayList;
- import java.util.List;
- import javax.xml.parsers.DocumentBuilder;
- import javax.xml.parsers.DocumentBuilderFactory;
- import org.w3c.dom.Document;
- import org.w3c.dom.Element;
- import org.w3c.dom.Node;
- import org.w3c.dom.NodeList;
- import cn.itcast.model.Person;
- public class DomPersonService {
- public List<Person> getPersons(InputStream stream) throws Throwable
- {
- List<Person> list =new ArrayList<Person>();
- DocumentBuilderFactory factory =DocumentBuilderFactory.newInstance();
- DocumentBuilder builder =factory.newDocumentBuilder();
- Document dom = builder.parse(stream);//解析完成,并以dom树的方式存放在内存中。比较消耗性能
- //开始使用dom的api去解析
- Element root = dom.getDocumentElement();//根元素
- NodeList personNodes = root.getElementsByTagName("person");//返回所有的person元素节点
- //开始遍历啦
- for(int i=0;i<personNodes.getLength();i++)
- {
- Person person =new Person();
- Element personElement =(Element)personNodes.item(i);
- person.setId(new Integer( personElement.getAttribute("id")));//将person元素节点的属性节点id的值,赋给person对象
- NodeList personChildrenNodes =personElement.getChildNodes();//获取person节点的所有子节点
- //遍历所有子节点
- for(int j=0;j<personChildrenNodes.getLength();j++)
- {
- //判断子节点是否是元素节点(如果是文本节点,可能是空白文本,不处理)
- if(personChildrenNodes.item(j).getNodeType()==Node.ELEMENT_NODE)
- {
- //子节点--元素节点
- Element childNode =(Element)personChildrenNodes.item(j);
- if("name".equals(childNode.getNodeName()))
- {
- //如果子节点的名称是“name”.将子元素节点的第一个子节点的值赋给person对象
- person.setName(childNode.getFirstChild().getNodeValue());
- }else if("age".equals(childNode.getNodeValue()))
- {
- person.setAge(new Integer(childNode.getFirstChild().getNodeValue()));
- }
- }
- }
- list.add(person);
- }
- return list;
- }
- }
2)
SAX(Simple API for XML),是一个使用非常广泛的XML解析标准,通常使用Handler模式来处理XML文档,这种处理模式和我们平常习惯的理解方式很不同,身边也经常有一些朋友在刚接触SAX的时候会觉得理解起来有些困难。其实SAX并不复杂,只不过是换了一种思维方式,正如它的名字所表示的,为了让我们以更简单的方式来处理XML文档,下面我们就开始吧。
- package cn.itcast.service;
- import java.io.InputStream;
- import java.util.ArrayList;
- import java.util.List;
- import javax.xml.parsers.SAXParser;
- import javax.xml.parsers.SAXParserFactory;
- import org.xml.sax.Attributes;
- import org.xml.sax.SAXException;
- import org.xml.sax.helpers.DefaultHandler;
- import cn.itcast.model.Person;
- public class SAXPersonService {
- public List<Person> getPersons(InputStream inStream) throws Throwable
- {
- SAXParserFactory factory = SAXParserFactory.newInstance();//工厂模式还是单例模式?
- SAXParser parser =factory.newSAXParser();
- PersonParse personParser =new PersonParse();
- parser.parse(inStream, personParser);
- inStream.close();
- return personParser.getPerson();
- }
- private final class PersonParse extends DefaultHandler
- {
- private List<Person> list = null;
- Person person =null;
- private String tag=null;
- public List<Person> getPerson() {
- return list;
- }
- @Override
- public void startDocument() throws SAXException {
- list =new ArrayList<Person>();
- }
- @Override
- public void startElement(String uri, String localName, String qName,
- Attributes attributes) throws SAXException {
- if("person".equals(localName))
- {
- //xml元素节点开始时触发,是“person”
- person = new Person();
- person.setId(new Integer(attributes.getValue(0)));
- }
- tag =localName;//保存元素节点名称
- }
- @Override
- public void endElement(String uri, String localName, String qName)
- throws SAXException {
- //元素节点结束时触发,是“person”
- if("person".equals(localName))
- {
- list.add(person);
- person=null;
- }
- tag =null;//结束时,需要清空tag
- }
- @Override
- public void characters(char[] ch, int start, int length)
- throws SAXException {
- if(tag!=null)
- {
- String data = new String(ch,start,length);
- if("name".equals(tag))
- {
- person.setName(data);
- }else if("age".equals(tag))
- {
- person.setAge(new Integer(data));
- }
- }
- }
- }
- }
3)
Pull解析和Sax解析很相似,都是轻量级的解析,在Android的内核中已经嵌入了Pull,所以我们不需要再添加第三方jar包来支持Pull。Pull解析和Sax解析不一样的地方有(1)pull读取xml文件后触发相应的事件调用方法返回的是数字(2)pull可以在程序中控制想解析到哪里就可以停止解析。
- package cn.itcast.service;
- import java.io.InputStream;
- import java.io.Writer;
- import java.util.ArrayList;
- import java.util.List;
- import org.xmlpull.v1.XmlPullParser;
- import org.xmlpull.v1.XmlSerializer;
- import android.util.Xml;
- import cn.itcast.model.Person;
- public class PullPersonService {
- //保存xml文件
- public static void saveXML(List<Person> list,Writer write)throws Throwable
- {
- XmlSerializer serializer =Xml.newSerializer();//序列化
- serializer.setOutput(write);//输出流
- serializer.startDocument("UTF-8", true);//开始文档
- serializer.startTag(null, "persons");
- //循环去添加person
- for (Person person : list) {
- serializer.startTag(null, "person");
- serializer.attribute(null, "id", person.getId().toString());//设置id属性及属性值
- serializer.startTag(null, "name");
- serializer.text(person.getName());//文本节点的文本值--name
- serializer.endTag(null, "name");
- serializer.startTag(null, "age");
- serializer.text(person.getAge().toString());//文本节点的文本值--age
- serializer.endTag(null, "age");
- serializer.endTag(null, "person");
- }
- serializer.endTag(null, "persons");
- serializer.endDocument();
- write.flush();
- write.close();
- }
- public List<Person> getPersons(InputStream stream) throws Throwable
- {
- List<Person> list =null;
- Person person =null;
- XmlPullParser parser =Xml.newPullParser();
- parser.setInput(stream,"UTF-8");
- int type =parser.getEventType();//产生第一个事件
- //只要当前事件类型不是”结束文档“,就去循环
- while(type!=XmlPullParser.END_DOCUMENT)
- {
- switch (type) {
- case XmlPullParser.START_DOCUMENT:
- list = new ArrayList<Person>();
- break;
- case XmlPullParser.START_TAG:
- String name=parser.getName();//获取解析器当前指向的元素名称
- if("person".equals(name))
- {
- person =new Person();
- person.setId(new Integer(parser.getAttributeValue(0)));
- }
- if(person!=null)
- {
- if("name".equals(name))
- {
- person.setName(parser.nextText());//获取解析器当前指向的元素的下一个文本节点的文本值
- }
- if("age".equals(name))
- {
- person.setAge(new Integer(parser.nextText()));
- }
- }
- break;
- case XmlPullParser.END_TAG:
- if("person".equals(parser.getName()))
- {
- list.add(person);
- person=null;
- }
- break;
- }
- type=parser.next();//这句千万别忘了哦
- }
- return list;
- }
- }
下面是Model层的Person类的代码:
- package cn.itcast.model;
- public class Person {
- private Integer id;
- public Integer getId() {
- return id;
- }
- public void setId(Integer id) {
- this.id = id;
- }
- private String name;
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- private Integer age;
- public Integer getAge() {
- return age;
- }
- public void setAge(Integer age) {
- this.age = age;
- }
- public Person()
- {
- }
- public Person(Integer id, String name, Integer age) {
- this.id = id;
- this.name = name;
- this.age = age;
- }
- @Override
- public String toString() {
- return "Person [id=" + id + ", name=" + name + ", age=" + age + "]";
- }
- }
转载自:http://blog.csdn.net/dinglang_2009/article/details/6940225
android操作XML的几种方式(转)的更多相关文章
- C#操作xml的3种方式
C#操作Xml有很多种方式,这里写出个人常使用的三种方式 XmlDocument DataSet linq to xml 首先声明本次操作使用的xml文件:books.xml:内容如下 <?x ...
- Android处理XML的三种方式
http://www.cnblogs.com/zhangdongzi/archive/2011/04/14/2016434.html http://blog.csdn.net/zzp16/articl ...
- Android开发之使用sqlite3工具操作数据库的两种方式
使用 sqlite3 工具操作数据库的两种方式 请尊重他人的劳动成果,转载请注明出处:Android开发之使用sqlite3工具操作数据库的两种方式 http://blog.csdn.net/feng ...
- 简介C#读取XML的两种方式
简介C#读取XML的两种方式 作者: 字体:[增加 减小] 类型:转载 时间:2013-03-03 在程序中访问进而操作XML文件一般有两种模型,分别是使用DOM(文档对象模型)和流模型,使用DOM的 ...
- JAVA解析XML的四种方式
java解析xml文件四种方式 1.介绍 1)DOM(JAXP Crimson解析器) DOM是用与平台和语言无关的方式表示XML文档的官方W3C标准.DOM是以层次结构组织的节点或信息片断的集合.这 ...
- android 数据存储的几种方式
总体的来讲,数据存储方式有三种:一个是文件,一个是数据库,另一个则是网络.其中文件和数据库可能用的稍多一些,文件用起来较为方便,程序可以自己定义格式:数据库用起稍烦锁一些,但它有它的优点,比如在海量数 ...
- java解析xml的几种方式
java解析xml的几种方式 DOM DOM的全称是Document ObjectModel,也即文档对象模型.在应用程序中,基于DOM的XML分析器将一个XML文档转换成一个对象模型的集合(通常称D ...
- uni-app&H5&Android混合开发三 || uni-app调用Android原生方法的三种方式
前言: 关于H5的调用Android原生方法的方式有很多,在该片文章中我主要简单介绍三种与Android原生方法交互的方式. 一.H5+方法调用android原生方法 H5+ Android开发规范官 ...
- Hadoop之HDFS文件操作常有两种方式(转载)
摘要:Hadoop之HDFS文件操作常有两种方式,命令行方式和JavaAPI方式.本文介绍如何利用这两种方式对HDFS文件进行操作. 关键词:HDFS文件 命令行 Java API HD ...
随机推荐
- Spark Graphx In Action
两个重要的技术:Spark和graphs 本章节内容 为什么Spark是最先进的大数据处理系统 是什么让图可以以一种独特的方式来模拟关联数据 GraphX为什么会成规领先的图分析平台
- 什么是RST包,什么是三次握手,什么是四次握手 ---请进
一.RST包.本人学习后总结:RST包用于强制关闭TCP链接. TCP连接关闭的正常方法是四次握手.但四次握手不是关闭TCP连接的唯一方法. 有时,如果主机需要尽快关闭连接(或连接超时,端口或主机不可 ...
- jquery json ajax -2
如果使用的是虚拟空间, 那么你不能操纵/配置服务器上的php.ini配置文件 但是可以在自己的php文件中, 通过ini_set(...), 和一些对应的函数, 去重置(临时的,仅在当前文件中生效的) ...
- c/c++指针
指针主要分: 指向单一的某个对象/变量, 用于多态或函数指针, 这个不难 - 一级指针 其次是指向数组, 用来操作/遍历数组元素 - 一级/二级指针 指向数组的一级指针很简单了: p指向的是数组的元素 ...
- du: fts_read 失败: 无法分配内存
今天在查看一个大的文件时突然报出一个du: fts_read 失败: 无法分配内存的错误. 用 ulimit -a 查看下 core file size (blocks, -c) 0 data seg ...
- 一个简单的javascript深拷贝
var extendDeep = function(parent,child){ var i, toStr = Object.prototype.toString, astr = '[object A ...
- 使用css3来实现边框圆角效果
经常看到别人的网站有个边框来修饰文字区域,类似圆角矩形把文字环绕起来,特别有感觉,于是就试着用图片边框来修饰,但是用图片过多会拉慢网页的加载速度,能不能使用css3来实现边框圆角效果呢?当然borde ...
- (9)UI(容器)
1.基础容器 基础容器可以设置子容器布局.是否裁切子元素.填充颜色.背景图片资源等属性. 使用场景. 在官方示例中,大量使用了基础容器作布局管理,如下面的主界面中,用户名称,钻石和金币就使 ...
- APScheduler —— Python化的Cron
APScheduler全程为Advanced Python Scheduler,是一款轻量级的Python任务调度框架.它允许你像Cron那样安排定期执行的任务,并且支持Python函数或任意可调用的 ...
- HDU 4435 charge-station bfs图论问题
E - charge-station Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u ...