Android 下用 Pull 解析和生成 XML
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的更多相关文章
- 使用Pull解析器生成XML文件和读取xml文件
有些时候,我们需要生成一个XML文件,生成XML文件的方法有很多,如:可以只使用一个StringBuilder组拼XML内容,然后把内容写入到文件中:或者使用DOM API生成XML文件,或者也可以使 ...
- 使用Pull解析器生成XML文件
有些时候,我们需要生成一个XML文件,生成XML文件的方法有很多,如:可以只使用一个StringBuilder组拼XML内容,然后把内容写入到文件中:或者使用DOM API生成XML文件,或者也可以使 ...
- 无废话Android之android下junit测试框架配置、保存文件到手机内存、android下文件访问的权限、保存文件到SD卡、获取SD卡大小、使用SharedPreferences进行数据存储、使用Pull解析器操作XML文件、android下操作sqlite数据库和事务(2)
1.android下junit测试框架配置 单元测试需要在手机中进行安装测试 (1).在清单文件中manifest节点下配置如下节点 <instrumentation android:name= ...
- SAX解析和生成XML文档
原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本人声明.否则将追究法律责任. 作者: 永恒の_☆ 地址: http://blog.csdn.net/chenghui031 ...
- maven中使用dom4j解析、生成XML的简易方法
此片文章主要写一些关于如何在maven工程中使用dom4j来解析或生成XML的建议方法,实际可使用的写法不仅限于如下所写的样例代码.此处进攻快速入手和提供思路使用. 首先配置pom.xml中的依赖的包 ...
- 黎活明8天快速掌握android视频教程--15_采用Pull解析器解析和生成XML内容
1.该项目主要有下面的两个作用 (1)将xml文件解析成对象的List对象,xml文件可以来自手机本地,也可以来自服务器返回的xml数据 (2)强list对象保存成xml文件,xml保存到手机的内存卡 ...
- Android开发8——利用pull解析器读写XML文件
一.基本介绍 对XML解析有SAX和DOM等多种方式,Android中极力推荐xmlpull方式解析xml.xmlpull不仅可用在Android上同样也适用于javase,但在javase环境中需自 ...
- android下基本json串的生成与解析
以前就用过json串,不过是在java环境下面,如今转移到android环境下,java里面生成解析json串的jar包与android中自带的冲突,所以也只能用安卓自带的. 先前查网上的资料,感 ...
- 15_采用Pull解析器解析和生成XML内容
java还提供SAX和DOM用于解析XML Android还集成了Pull解析器——推荐 package cn.itcast.service; import java.io.InputStream; ...
随机推荐
- CoffeeScript飞一样的写javascript
之前看到同事在使用coffeescript写js,当我看到那简介的coffee文件,就深深的被coffescript吸引了,简洁的语法,熟练之后会大大提升javascript的开发速度,写脚本也能像飞 ...
- wamp安装注意点!
安装wamp前或者重装系统后,默认没有依赖的组件VC11,需要先安装才能运行 下载地址:http://www.microsoft.com/en-us/download/details.aspx?id= ...
- Hibernate报错 ** is not mapping
使用easyui+struts+hibernate 新增加一个页面功能时,总是报错,后来发现是数据库语句,不能写表名称,而是要写映射的数据库实体类名 1.struts文件修改增加action < ...
- DexIndexOverflowException: Cannot merge new index 66080 into a non-jumbo instruction!
问题 该问题是方法数超过了65536(DEX 64K problem),无法编译成单个dex文件. 解决方案 谷歌官方给出的解决方案 android { compileSdkVersion 21 bu ...
- source insight 使用技巧
一.在所有文件中查找字符串 1.菜单栏选择“search project” 2.在随便一个工程文件中把所要查找的字符串输入到空白的地方,然后点连接
- JAVA面试题相关基础知识
1.面向对象的特征有哪些方面 ①抽象: 抽象就是忽略一个主题中与当前目标无关的那些方面,以便更充分地注意与当前目标有关的方面.抽象并不打算了解全部问题,而只是选择其中的一部分,暂时不用部分细节 ...
- iOS版 hello,world版本2
// // main.m // Hello // // Created by lishujun on 14-8-28. // Copyright (c) 2014年 lishujun. All rig ...
- BZOJ 3595: [Scoi2014]方伯伯的Oj SBT+可持久化Treap
3595: [Scoi2014]方伯伯的Oj Time Limit: 6 Sec Memory Limit: 256 MBSubmit: 102 Solved: 54[Submit][Status ...
- BZOJ 4008 亚瑟王
Description 小K不慎被LL邪教洗脑了,洗脑程度深到他甚至想要从亚瑟王邪教中脱坑. 他决定,在脱坑之前,最后再来打一盘亚瑟王.既然是最后一战,就一定要打得漂亮.众所周知,亚瑟王是一个看脸的游 ...
- MFC窗口风格 WS_style/WS_EX_style(超详细)
窗口风格(Window style) WS_BORDER 有边框窗口 WS_CAPTION 必须和WS_BORDER风格配合,但不能与WS_DLGFRAME风格一起使用.指示窗口包含标题要部分 ...