Java 中是可以用 SAX 和 DOM 解析 XML  的,虽然在 Android 下也可以用这2中方式,但是还是推荐用 Pull。Pull 使用简单,效率相对高,Android 下是集成了 Pull ,所以并不需要用到第三方的包。

下面来举例子,我要向 XML 文档中读写学生信息,首先我定义一个学生类,包含ID、学号、姓名和年龄

public class Student {
public Student() {}; public Student(int id, int number, String name, int age) {
this.id = id;
this.number = number;
this.name = name;
this.age = age;
} private int id;
private int number;
private String name;
private int age; public int getId() {
return id;
}
public int getNumber() {
return number;
}
public String getName() {
return name;
}
public int getAge() {
return age;
}
public void setId(int id) {
this.id = id;
}
public void setNumber(int number) {
this.number = number;
}
public void setName(String name) {
this.name = name;
}
public void setAge(int age) {
this.age = age;
} @Override
public String toString() {
return "Student [number=" + number + ", name=" + name + ", age=" + age
+ "]";
}
}

要读取的 XML 文件里面内容是这样的

<?xml version="1.0" encoding="UTF-8"?>
<students>
<student id="1">
<number>33</number>
<name>张三</name>
<age>20</age>
</student>
<student id="2">
<number>29</number>
<name>李四</name>
<age>19</age>
</student>
</students>

然后我写了个 XmlHelper 类,有个静态方法 getStudes,该方法接受输入流,返回学生信息的集合

public static List<Student> getStudents(InputStream xml) throws Exception {
List<Student> students = null;
Student student = null;
XmlPullParser parser = Xml.newPullParser(); //得到 Pull 解析器
parser.setInput(xml, "UTF-8"); //设置输入,编码为 UTF-8 int event = parser.getEventType(); //得到事件类型,每读取到一个位置都有相对的事件类型
while (XmlPullParser.END_DOCUMENT != event) { //没到文档结尾就要循环读取
switch (event) { case XmlPullParser.START_DOCUMENT: //这是文档开始事件,我们在这个地方做一些初始化工作
students = new ArrayList<Student>();
break; case XmlPullParser.START_TAG: //标签开始事件,标签开始就是上面XML中的 <students>、<student>、<number>、<name>、和 <age>
if (parser.getName().equals("student")) { //读取到这个 student 标签就说明下面就是我需要的信息了
int id = Integer.valueOf(parser.getAttributeValue(0));
student = new Student();
student.setId(id);
}
if (null != student) { //避免出现空指针,先判断一下再继续
if (parser.getName().equals("number")) {
int number = Integer.valueOf(parser.nextText()); // nextText() 就是得到标签后面的文本
student.setNumber(number);
}else if (parser.getName().equals("name")) {
String name = parser.nextText();
student.setName(name);
}else if (parser.getName().equals("age")) {
int age = Integer.valueOf(parser.nextText());
student.setAge(age);
}
}
break; case XmlPullParser.END_TAG:
//读取到 </student> 时说明一个学生的信息已经读取完了
if (parser.getName().equals("student")) {
students.add(student);
student = null;
}
break; default:
break;
}
event = parser.next(); //一个读取完了,就下一个,如此循环
}
return students;
}

读取就是这样了,接下来写怎样生成。generate 方法,接受学生信息集合和输出流

其实成成很好理解,就是按照顺序一块信息一块信息写下去

public static void generate(List<Student> students, OutputStream os) throws Exception {
XmlSerializer serializer = Xml.newSerializer(); //得到序列化器
serializer.setOutput(os, "UTF-8"); //设置输出
serializer.startDocument("UTF-8", true); //文档开始了
serializer.startTag(null, "students"); //标签开始了
for (Student student : students) {
serializer.startTag(null, "student"); //子标签开始了
serializer.attribute(null, "id", String.valueOf(student.getId())); //指定该标签属性,这里是ID //下面3个就是生成学号、姓名和年龄
serializer.startTag(null, "number");
serializer.text(String.valueOf(student.getNumber()));
serializer.endTag(null, "number"); serializer.startTag(null, "name");
serializer.text(student.getName());
serializer.endTag(null, "name"); serializer.startTag(null, "age");
serializer.text(String.valueOf(student.getAge()));
serializer.endTag(null, "age"); serializer.endTag(null, "student"); //子标签结束
}
serializer.endTag(null, "students"); //标签结束
serializer.endDocument(); //文档结束
os.flush(); //如果传入的输出流不是文件,就就要刷新一下缓冲区
os.close();
}
}

然后咱来写一个测试单元来测试一下这俩方法

public class XmlHelperTest extends AndroidTestCase {
private static final String TAG = "XmlHelperTest"; public void testGetStudents() throws Exception {
InputStream xmlIstm = this.getClass().getClassLoader().getResourceAsStream("students.xml");
List<Student> students = XmlHelper.getStudents(xmlIstm);
for (Student student : students) {
Log.i(TAG, student.toString());
}
} public void testGenerate() throws Exception {
List<Student> students = new ArrayList<Student>();
students.add(new Student(1, 13, "小建", 21));
students.add(new Student(2, 16, "大康", 20)); File xmlFile = new File(getContext().getFilesDir(), "students.xml");
FileOutputStream fos = new FileOutputStream(xmlFile);
try {
XmlHelper.generate(students, fos);
Log.i(TAG, "生成XML文件成功");
} catch(Exception e) {
Log.i(TAG, "生成XML文件失败:" + e.getMessage());
}
}
}

-----------------------

楼主以前都是写 C++ 的,也才学 Android 不久,加油吧。

好久没写博客了,感觉吧,还是应该坚持写下去。

Android 下用 Pull 解析和生成 XML的更多相关文章

  1. 使用Pull解析器生成XML文件和读取xml文件

    有些时候,我们需要生成一个XML文件,生成XML文件的方法有很多,如:可以只使用一个StringBuilder组拼XML内容,然后把内容写入到文件中:或者使用DOM API生成XML文件,或者也可以使 ...

  2. 使用Pull解析器生成XML文件

    有些时候,我们需要生成一个XML文件,生成XML文件的方法有很多,如:可以只使用一个StringBuilder组拼XML内容,然后把内容写入到文件中:或者使用DOM API生成XML文件,或者也可以使 ...

  3. 无废话Android之android下junit测试框架配置、保存文件到手机内存、android下文件访问的权限、保存文件到SD卡、获取SD卡大小、使用SharedPreferences进行数据存储、使用Pull解析器操作XML文件、android下操作sqlite数据库和事务(2)

    1.android下junit测试框架配置 单元测试需要在手机中进行安装测试 (1).在清单文件中manifest节点下配置如下节点 <instrumentation android:name= ...

  4. SAX解析和生成XML文档

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本人声明.否则将追究法律责任. 作者: 永恒の_☆ 地址: http://blog.csdn.net/chenghui031 ...

  5. maven中使用dom4j解析、生成XML的简易方法

    此片文章主要写一些关于如何在maven工程中使用dom4j来解析或生成XML的建议方法,实际可使用的写法不仅限于如下所写的样例代码.此处进攻快速入手和提供思路使用. 首先配置pom.xml中的依赖的包 ...

  6. 黎活明8天快速掌握android视频教程--15_采用Pull解析器解析和生成XML内容

    1.该项目主要有下面的两个作用 (1)将xml文件解析成对象的List对象,xml文件可以来自手机本地,也可以来自服务器返回的xml数据 (2)强list对象保存成xml文件,xml保存到手机的内存卡 ...

  7. Android开发8——利用pull解析器读写XML文件

    一.基本介绍 对XML解析有SAX和DOM等多种方式,Android中极力推荐xmlpull方式解析xml.xmlpull不仅可用在Android上同样也适用于javase,但在javase环境中需自 ...

  8. android下基本json串的生成与解析

    以前就用过json串,不过是在java环境下面,如今转移到android环境下,java里面生成解析json串的jar包与android中自带的冲突,所以也只能用安卓自带的.   先前查网上的资料,感 ...

  9. 15_采用Pull解析器解析和生成XML内容

    java还提供SAX和DOM用于解析XML Android还集成了Pull解析器——推荐 package cn.itcast.service; import java.io.InputStream; ...

随机推荐

  1. MVVM模式应用 之介绍

    M-V-VM (1)M:即Model,由现实世界抽象出来的模型: V:即View,视图,界面,该界面与用户输入设备进行交互: 但是View与Model如何进行交互呢? Binding便可以发挥作用了, ...

  2. Eclipse中文乱码解决汇总(应该比较全):

    Eclipse中文乱码解决汇总(应该比较全,欢迎补充): 方法一: 把GBK改成utf-8. 方法二: Window->preference->general->content ty ...

  3. Mac OS X 好用的软件包管理工具 Homebrew

    github地址:https://github.com/Homebrew/homebrew 安装方法:http://brew.sh/

  4. 彻底删除sql2008r2

    一.    SQL2008卸载. 1.从控制面板卸载 1)点击计算机右下角“开始”,点击“控制面板” 2)点击“卸载程序”. 3)在程序列表中找到“Microsoft SQL Server 2008” ...

  5. JavaScript学习总结【1】、初识JS

    1.什么是 JavaScript? JavaScript 是一门跨平台.面向对象的动态的弱类型的轻量级解释型语言,是一种基于对象和事件驱动并具有相对安全性的客户端脚本语言.应用于 HTML 文档能够在 ...

  6. HierarchyView的实现原理和Android设备无法使用HierarchyView的解决方法

    声明:由于本人一直用eng版的真机调试,所以此方法没有用过,记录在这里,有机会验证 ---------------------------------------------------------- ...

  7. SuperSocket与Netty之实现protobuf协议,包括服务端和客户端

    今天准备给大家介绍一个c#服务器框架(SuperSocket)和一个c#客户端框架(SuperSocket.ClientEngine).这两个框架的作者是园区里面的江大渔. 首先感谢他的无私开源贡献. ...

  8. JS面向对象思想(OOP)

    直接看js好了,模拟创建一个奥运会 function 奥运会Class(主题) { // 删除主题 // delete this.主题; this.主题 = 主题; this.开幕时间; this.闭 ...

  9. 我学C的那些年[ch02]:宏,结构体,typedef

    c语言的编译过程: 预处理 编译 汇编 链接 而预处理中有三种情况: 文件包含( #include ) 条件编译(#if,#ifndef,#endif) 宏定义( #define ) 宏就是预处理中的 ...

  10. 局部视图(partial)

    局部视图(partial) 原文:Partial Views作者:Steve Smith翻译:张海龙(jiechen).刘怡(AlexLEWIS)校对:许登洋(Seay).何镇汐.魏美娟(初见) AS ...