目的:将Person对象的id、name、age属性写成一个xml文件保存到本地,并能够读取和解析该文件。
一、序列化xml文件到本地
此过程将java对象写成xml对象,必须用到XmlSerializer。写xml文件时,常用到XmlSerializer下的几个重要方法:
(1)设置输出流编码格式
setOutput(OutputStream os, String encoding)
(2)写整个xml文件的头标签名
setStartDocument(String encoding, Boolean standalone)
(3)写头尾属性名
startTag() / endTag()
(4)写一个标签名的属性
attribute(String namespace, String name, String value)
(5)写属性名对应的字段值
text(String text)
/**
* 写xml到本地
*/
private void writeXmlToLocal() {
List<Person> personList = getPersonList();
try {
XmlSerializer serializer = Xml.newSerializer(); //获得序列化对象
File file = new File(Environment. getExternalStorageDirectory(), "persons.xml"); //定义xml文件存储的路径
FileOutputStream fos = new FileOutputStream(file);
serializer.setOutput(fos, "utf_8");
serializer.startDocument("utf-8", true); //写头标签名<?xml ......./>,编码为utf-8
serializer.startTag(null, "persons"); //<persons>
serializer.endTag(null, "persons"); //</persons>
for (Person person : personList) {
//开始写人
serializer.startTag(null, "person"); //<person>
serializer.attribute(null, "id", String.valueOf(person.getId()));
//写名字
serializer.startTag(null, "name");
serializer.text(person.getName());
serializer.endTag(null, "name");
//写年龄
serializer.startTag(null, "age");
serializer.text(String.valueOf(person.getAge()));
serializer.endTag(null, "age");
serializer.endTag(null, "person"); //</person>
}
serializer.endTag(null, "person");
serializer.endDocument(); //结束
} catch (Exception e) {
e.printStackTrace();
}
}
二、从本地读取并解析xml文件
本例使用pull解析进行操作。
首先,将用于解析的XmlPullParser类进行实例化,得到parser。parser的主要方法有:
(1)指定解析的文件和编码格式
setInput()
(2)获得事件类型
getEventType()
(3)获取当前标签的名称
getName()
(4)获取属性值
getAttributeValue()
(5)获得下一个字段值
nextText()
(6)获得下一个事件类型
next()
//解析xml文件
private List<Person> parserXmlFromLocal() {
try {
File file = new File(Environment.getExternalStorageDirectory(), "persons.xml"); //xml存在的路径
FileInputStream fis = new FileInputStream(file);
//获得pull解析器对象
XmlPullParser parser = Xml.newPullParser();
//指定解析的文件和编码格式
parser.setInput(fis, "utf-8");
//获得事件类型
int eventType = parser.getEventType();
List<Person> personList = null;
Person person = null;
String id;
//eventType有点类似于游标,当它没有移动至xml结束时,执行下面解析操作:
while(eventType != XmlPullParser.END_DOCUMENT) {
String tagName = parser.getName();
switch (eventType) {
case XmlPullParser.START_TAG: //当前等于开始节点<person>
if("persons".equals(tagName)) { //<persons>
personList = new ArrayList<Person>();
} else if("person".equals(tagName)) {
person = new Person();
id = parser.getAttributeValue(null, "id");
person.setId(Integer.valueOf(id));
} else if("name".equals(tagName)) {
person.setName(parser.nextText());
} else if("age".equals(tagName)) {
person.setAge(Integer.parseInt(parser.nextText()));
}
break;
case XmlPullParser.END_TAG:
if("person".equals(tagName)) {
//需要把上面设置好的person对象添加到集合中
personList.add(person);
}
break;
default:
break;
}
eventType = parser.next(); //获得下一个事件类型
}
return personList;
} catch (Exception e) {
e.printStackTrace();
}
return null;
}