对于XML是什么,这里就不多说了,如果不懂可以google学习下。
xml是非常重要和常用的一种数据格式
XML序列化
步骤:
- 生成一个序列化器
XmlSerializer serializer = Xml.newSerializer(); - 要把数据输出到哪里,并设置编码格式:输出流
serializer.setOutput(FileOutputStream, "utf-8"); - 通过序列化器写标签
标签和属性中的第一个参数是 命名空间,一般为 null 即可
serializer.startDocument("utf-8", true); //开始文档,true表示与其他xml文件无关联
serializer.startTag(null, "开始节点");
serializer.attribute(null, "属性名", "属性值"); //属性可写可不写
serializer.text("节点的内容");
serializer.endTag(null, "结束节点");
serializer.endDocument(); //结束文档
- 关闭流
pull解析
特点
- 边导入边解析,基于事件驱动方式
- 解析完一个节点后,返回该节点的事件类型,通过该事件类型做相应的业务处理
- 当解析完一个节点后,它不会继续往下解析,需要手动指向下一个节点,继续解析
- android默认采用pull解析
步骤
- 先构建一个解析器
XmlPullParser parser = Xml.newPullParser(); - 设置要解析的内容
parser.setInput(is, "utf-8"); - 获取节点的事件类型来解析内容
pull的事件类型
XmlPullParser.START_DOCUMENT:文档开始
XmlPullParser.END_DOCUMENT:文档结束
XmlPullParser.START_TAG:开始标记
XmlPullParser.END_TAG:结束标记
解析过程
int event = parser.getEventType();//获取当前节点的事件类型
while(event != XmlPullParser.END_DOCUMENT) {
switch(event) {
case XmlPullParser.START_DOCUMENT :
//TODO 一般进行数据的初始化操作
break;
case XmlPullParser.START_TAG :
//TODO 解析
String tag = parser.getName();//获取当前节点的标记
parser.getAttributeValue(0);//获取当前节点的第一个属性值
String text = parser.nextText();//获得当前里的文本内容
break;
case XmlPullParser.END_TAG:
//TODO 将数据进行保存操作
break;
}
event = parser.next(); //指向下一个节点
}
案例
详情请看我在GitHub上的demo