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. 237. Delete Node in a Linked List(C++)

    237. Delete Node in a Linked Lis t Write a function to delete a node (except the tail) in a singly l ...

  2. Photon引擎开发实战(1)——Photon 简介

    Photon简介 Photon是一套使用广泛的socket server引擎,服务端底层C++编写,客户端C#编写,跨多平台,收费,效率可观的一款引擎.实用上前有九城游戏(原魔兽世界代理),现在笔者发 ...

  3. Windows Phone 之播放视频

    在Windows Phone 7中播放视频有两种方式, (1)使用MediaElement 控件来播放:用MediaElement 控件来播放视频比较灵活,你需要自己去实现播放暂停进度条等等的功能,播 ...

  4. 【原创】CMD常用命令:解决实际问题

    1.查找某一目录下后缀名文某某的所有文件. 命令格式:dir *.mp3 /a -d/b/s >C:\Users\leemo\Desktop\total.txt MP3为文件后缀名.>是命 ...

  5. 【原创】win7同局域网下共享文件

    本文章用于解决win7局域网共享文件问题: 首先保证两台机器可以ping通: 检测方法: win+R输入cmd打开命令行,输入ping  对方主机ip 不知对方ip可以在在命令行中输入ipconfig ...

  6. Global & Local Variable in Python

    Following code explain how 'global' works in the distinction of global variable and local variable. ...

  7. WebApi(四)-Post接口请求失败或接受不到参数(解决方法)

    post方式只能接受一个参数而且必须用FromBody特性标识,所以当没有使用FromBody特性标识的时候就会请求失败,如有添加添加了那访问接口时候参数应传对象不能是key:val的格式否则会接收到 ...

  8. Ubuntu下安装nvidia显卡驱动

    layout: post title: Ubuntu下安装nvidia显卡驱动 date: 2015-10-02 17:19:06 categories: 常用命令 tags: 显卡 驱动 最近一直在 ...

  9. jquery中each遍历对象和数组示例

    通用遍历方法,可用于遍历对象和数组.$().each(),回调函数拥有两个参数: 第一个为对象的成员或数组的索引,第二个为对应变量或内容.如需退出each循环可使回调函数返回false 现有如下两个s ...

  10. spoj 3885

    简单的博弈题,用dp解: 每个人只能拿1,l,k个硬币: dp[i][j]表示第j个人拿是否能拿第i枚硬币: 代码: #include<cstdio> #define maxn 10000 ...