、生成XML文件,即是将对象集合转为XML文件存储。
对象集合 –> XML(序列化)

Android中使用android.util.Xml类对其进行了描述,提供相应的API。
步骤大致如下:

  1. 创建一个XmlSerializer类的实例,XmlSerializer serializer = Xml.newSerializer()。
  2. 使用openFileOutput准备一个输出流,指定输出的xml文件名及该文件权限。
  3. 给序列化serializer对象设置输出流和编码格式。
  4. serializer设置xml的编码格式,文档的开始。
  5. serializer设置xml的根节点,根节点的标签。
  6. 使用for循环遍历集合中的所有对象,为每一个对象写入标签和属性。
  7. 根节点的结束。
  8. 文档的结束。

测试代码如下:

准备一个数据模型PersonInfo类

public class PersonInfo {

    public int id;
public String name;
public int age; public PersonInfo() {
super();
} public PersonInfo(int id, String name, int age) {
this.id = id;
this.name = name;
this.age = age;
} @Override
public String toString() {
return "PersonInfo{" +
"id=" + id +
", name='" + name + '\'' +
", age=" + age +
'}';
}
}

然后在MainActivity中准备一个按钮,生成XML。

/**
* 按钮点击事件,对象集合->XML
* @param view
*/
public void createXml(View view){
try {
// 准备一个集合
List<PersonInfo> infos = new ArrayList<PersonInfo>();
// 添加两个对象数据
infos.add(new PersonInfo(1, "老王", 20));
infos.add(new PersonInfo(2, "老张", 30));
// 把对象集合变为XML
XmlSerializer serializer = Xml.newSerializer();
FileOutputStream os = openFileOutput("persons.xml", Context.MODE_PRIVATE); // 指定输出的文件名及其访问权限
serializer.setOutput(os, "utf-8"); // 指定输出流及编码格式
serializer.startDocument("utf-8", true); // 文档的开始
serializer.startTag(null, "persons"); // 根节点的开始
// 给每个对象写入标签和属性
for(PersonInfo info:infos){
// 属性
serializer.startTag(null, "person");
serializer.attribute(null, "id", info.id + "");
// name
serializer.startTag(null, "name");
serializer.text(info.name); // 文本节点
serializer.endTag(null, "name");
// age
serializer.startTag(null, "age");
serializer.text(info.age + "");
serializer.endTag(null, "age"); serializer.endTag(null, "person");
} serializer.endTag(null, "persons"); // 根节点的结束
serializer.endDocument(); // 文档的结束 os.close(); // 关流 } catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}

运行程序,点击生成XML按钮后,在data/data/包名/files路径下生成了persons.xml文件。

导出该文件,看内容如下(无换行、无缩进):

<?xml version='1.0' encoding='utf-8' standalone='yes' ?><persons><person id="1"><name>老王</name><age>20</age></person><person id="2"><name>老张</name><age>30</age></person></persons>

手动调整了一下,可见效果如下:

<?xml version='1.0' encoding='utf-8' standalone='yes' ?>
<persons>
<person id="1">
<name>老王</name>
<age>20</age>
</person>
<person id="2">
<name>老张</name>
<age>30</age>
</person>
</persons>

、解析XML文件,即是将XML文件转为对象集合。
XML –> 对象集合 (反序列化)

Android中解析XML有三种方法:SAX、DOM、PULL,这里使用Android内置的Pull解析。
需要使用XmlPullParser类,步骤大致如下:

  1. 获得一个XmlPullParser类的实例。
  2. 给parser解析器对象设置xml文件及其编码格式。
  3. 从parser解析器对象身上获取解析到的事件类型。
  4. 用switch语句处理不同事件类型。

其中,事件类型有以下几种:

eventType mean
START_DOCUMENT 文档开始
START_TAG 标签开始
TEXT 内容
START_END 标签结束
END_DOCUMENT 文档结束

在MainActivity中添加一个按钮,解析使用之前生成的persons.xml,代码如下:

/**
* 按钮点击事件,解析xml文件。XML --> 对象集合
* @param view
*/
public void parseXml(View view){
List<PersonInfo> infos = null;
PersonInfo info = null;
try {
// 获取解析器
XmlPullParser parser = Xml.newPullParser();
// 准备一个输入流,传入要解析的xml文件
FileInputStream inputStream = openFileInput("persons.xml");
parser.setInput(inputStream, "utf-8"); // 把流设置给解析器
int eventType = parser.getEventType(); // 获取事件类型 while(eventType != XmlPullParser.END_DOCUMENT){ // 判断是否解析到了文档的结尾
switch (eventType) {
case XmlPullParser.START_TAG: // 标签的开始
if("persons".equals(parser.getName())){ // 获取当前标签的名称,根节点的开始
infos = new ArrayList<PersonInfo>();
}else if("person".equals(parser.getName())){ // 获取当前标签的名称,一个对象的开始
info = new PersonInfo();
int id = Integer.parseInt(parser.getAttributeValue(0)); // 获取属性
info.id = id;
}else if("name".equals(parser.getName())){
String name = parser.nextText(); // 获取下一个文本节点的值
info.name = name;
}else if("age".equals(parser.getName())){
int age = Integer.parseInt(parser.nextText());
info.age = age;
}
break;
case XmlPullParser.END_TAG: // 标签的结束
if("person".equals(parser.getName())){
infos.add(info);
info = null;
}
break; default:
break;
}
// 还没到文档的结尾,继续往下解析
eventType = parser.next();
}
//打印日志
for(PersonInfo personInfo:infos){
Log.i(TAG, personInfo.toString());
} } catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}

以上代码的模板代码可以在XmlPullParser类的文档上看到!
运行后,点击解析XML按钮,结果如下:


其他:看了下边这篇博文,记录一下一个值得注意的点。

http://blog.csdn.net/onlyonecoder/article/details/8489170

【Android】使用Pull生成/解析XML文件的更多相关文章

  1. Android 使用pull,sax解析xml

    pull解析xml文件 1.获得XmlpullParser类的引用 这里有两种方法 //解析器工厂 XmlPullParserFactory factory=XmlPullParserFactory. ...

  2. 使用pull方式解析xml文件示例:

    网上的示例太多,基本类似,个人在此做个简单的总结: 1.首先在工程的asserts目录下建一个book.xml文件: <?xml version="1.0" encoding ...

  3. android使用XmlPullParser来解析XML文件

    解析下面的一个XML: <?xml version="1.0" encoding="utf-8" ?> <rss><sid> ...

  4. Pull方式解析XML文件

    package com.pingyijinren.test; import android.content.Intent; import android.os.Handler; import andr ...

  5. Android pull解析xml文件

    本文介绍android中使用pull来解析xml文件 先自己写一个xml文件,存一些天气信息 <?xml version="1.0" encoding="UTF-8 ...

  6. android——使用pull解析xml文件

    1.persons.xml 将persons.xml文件放到src目录下.其代码如下: <?xml version='1.0' encoding='UTF-8' standalone='yes' ...

  7. android 生成、pull解析xml文件

    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools= ...

  8. [android] 采用pull解析xml文件

    /***********2016年5月6日 更新**********************/ 知乎:Android 中有哪几种解析 xml 的类,官方推荐哪种 ? 以及它们的原理和区别? 刘吉财: ...

  9. Android SAX、DOM、Pull解析xml文件剖析与案例讲解

    XML介绍 XML(Extensible Markup Language) 即可扩展标记语言,与HTML一样,都是SGML(Standard Generalized Markup Language,标 ...

随机推荐

  1. JavaScript-jQuery插件开发全解析

    摘自:http://www.iteye.com/topic/545971 jQuery插件的开发包括两种: 一种是类级别的插件开发,即给jQuery添加新的全局函数,相当于给jQuery类本身添加方法 ...

  2. LinkedHashMap插入无序且链式操作

    Iterator<Entry<Integer, Integer>> ite=lhmap.entrySet().iterator(); ite.next(); ite.remov ...

  3. '<>' operator is not allowed for source level below 1.7

    报错:'<>' operator is not allowed for source level below 1.7 这是eclipse的编译环境与项目的要求不对应造成的,这个错误一般是导 ...

  4. HDUOJ---1863畅通工程

    畅通工程 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submis ...

  5. HDUOJ----(2612)Find a way

    Find a way Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  6. 分布式缓存技术memcached学习系列(二)——memcached基础命令

    上文<linux环境下编译memcahed>介绍了memcahed在linux环境下的安装以及登录,下面介绍memcahed的基本命令的使用. Add 功能:往内存增加一条新的缓存记录 语 ...

  7. Android 手机上获取物理唯一标识码

    唯一标识码这东西在网络应用中非常有用,例如检测是否重复注册之类的. import android.provider.Settings.Secure;private String android_id ...

  8. STL应用之set

    之前在解决一道算法题的时候,应用到set,特意对这个stl的容器类做了一些了解.在我的印象中,set就是一个元素不重复的集合,而事实上也正是这样的.无论从MSDN还是任何其它地方,都会告诉我们set的 ...

  9. SVN版本控制业务流程详解

    http://blog.sina.com.cn/s/blog_56d8ea900100y9cf.html http://jingyan.baidu.com/article/fa4125acbf509e ...

  10. Cordic算法简介

    作者:桂. 时间:2017-08-14  19:22:26 链接:http://www.cnblogs.com/xingshansi/p/7359940.html 前言 CORDIC算法常用来求解信号 ...