您的位置:首页 > 其它

Xml格式数据的生成和解析

2016-12-14 17:41 197 查看

1. Xml格式数据的生成和解析

使用xml 作为数据交互的载体是Android
中非常重要的功能,比如天气预报数据、短信备份数据、讯录数据都可以以xml
的格式通过网络传输。

XML的格式通过便签的形式书写和展示,一目了然,方便阅读和识别,如下所示:

<xml 头>

<student>

<name>张三</name>

<number>110001</number>

<sex>male</sex>

</student>

 XML的生成

如果用java代码去实现这样的一个字符串格式,可以使用到StringBuilder来进行组拼:

StringBuilder sb = new StringBuilder();

//数据保存到文件

sb.append("<?xml version=\"1.0\" encoding=\"utf-8\"?>");

sb.append("<student>");

sb.append("<name>");

sb.append(name);

sb.append("</name>");

sb.append("<number>");

sb.append(number);

sb.append("</number>");

sb.append("<sex>");

sb.append(sex);

sb.append("</sex>");

sb.append("</student>");

上面的代码虽然也可以生成xml
文件,但是无法对特殊字符进行处理,比如如果短信内容包含“</>”符号,那么xml
解析器就无法完成正确的解析。因此使用的前提是你确定数据内容没有特殊字符。

而Android为我们提供了一个专门用于生成XML数据的API:XmlSerializer, 该api
内部已经实现了对特殊字符的处理,代码如下:

try {

//
采用Android的api面向对象的生成xml文件.

// 1.得到xml文件的序列化器

XmlSerializer serializer = Xml.newSerializer();

// 2.指定序列化器的一些初始参数

File file = new File(getFilesDir(), name +
".xml");

FileOutputStream os = new FileOutputStream(file);

serializer.setOutput(os,
"utf-8");

// 3.写xml文件.

serializer.startDocument("utf-8",
true);//写开头

serializer.startTag(null,
"student");//开始标签

serializer.startTag(null,
"name");

serializer.text(name);//文本标签

serializer.endTag(null,
"name");//结束标签

 

serializer.startTag(null,
"number");

serializer.text(number);

serializer.endTag(null,
"number");

 

serializer.startTag(null,
"sex");

serializer.text(sex);

serializer.endTag(null,
"sex");

 

serializer.endTag(null,
"student");

serializer.endDocument();//写结尾

os.close();

Toast.makeText(this,
"保存数据成功", 0).show();

} catch (Exception e) {

e.printStackTrace();

Toast.makeText(this,
"保存数据失败", 0).show();

}

XML的解析

1. DOM解析 

是一种基于对象的API,它会将XML文件的所有内容以文档树方式存放在内存中,然后允许使用DOM
API遍历XML树、检索所需的数据,这样便能根据树的结构以节点形式来对文件进行操作。由于DOM需要将整个XML文件以文档树的形式存放在内存中,消耗内存比较大,在Android下不介意使用该种方式进行解析。

2. SAX解析 

 会逐行扫描XML文档,当遇到标签时触发解析处理器,采用事件处理的方式解析XML。它在读取文档的同时即可对XML进行处理,不必等到文档加载结束,相对快捷,而且也不需要将整个文档加载进内存,因此不存在占用内存的问题,可以解析超大XML。但是,SAX解析只能用来读取XML的数据,无法进行增删改。

3. PULL解析

 跟SAX解析类似,也是基于事件处理的方式。PULL解析器是一个开源的Java项目,既可以用于Android应用,也可以用与JavaEE程序。Android已经集成了PULL解析器,因此,在android中最常用的解析方式就是PULL解析。

 

SAX和PULL解析对比

Pull 解析器的运行方式与SAX
解析器相似,都属于事件驱动模式。它提供了类似的事件,如:开始元素和结束元素事件,使用parser.next()可以进入下一个元素并触发相应事件。事件将作为数值代码被发送,因此可以使用一个switch
对感兴趣的事件进行处理。当元素开始解析时,调用parser.nextText()方法可以获取下一个Text
类型元素的值。

SAX 解析器的工作方式是自动将事件推入事件处理器进行处理,因此你不能控制事件的处理主动结束;而Pull
解析器的工作方式为允许你的应用程序代码主动从解析器中获取事件,正因为是主动获取事件,因此可以在满足了需要的条件后不再获取事件,结束解析。

 

Android下使用PULL方式解析XML文件的代码如下:

try {

//学生信息的xml文件存在

//1.获取到一个xml解析器

XmlPullParser parser = Xml.newPullParser();

//2.设置解析器的初始化参数

FileInputStream inputStream = new FileInputStream(file);

parser.setInput(inputStream,
"utf-8");

//3.解析xml文件

int type = parser.getEventType();
//得到第一个事件的类型.

System.out.println("type:"+type);

StringBuilder sb = new StringBuilder();

//当事件类型不是文档的结尾则一直遍历每一个节点

while(type!=XmlPullParser.END_DOCUMENT){

if(type==XmlPullParser.START_TAG){

//开始节点

//判断节点的名称

if("name".equals(parser.getName())){

String nameStr = parser.nextText();

System.out.println("姓名:"+nameStr);

sb.append("姓名:"+nameStr+"\n");

}else if("number".equals(parser.getName())){

String numberStr = parser.nextText();

System.out.println("学号:"+numberStr);

sb.append("学号:"+numberStr+"\n");

}else if("sex".equals(parser.getName())){

String sexStr = parser.nextText();

System.out.println("性别:"+sexStr);

sb.append("性别:"+sexStr+"\n");

}

}

type = parser.next();//获取下一个事件类型

System.out.println("type:"+type);

}

inputStream.close();//浪费资源 造成内存泄漏!

tv_result.setText(sb.toString());

} catch (Exception e) {

e.printStackTrace();

Toast.makeText(this,
"解析学生信息失败", 0).show();

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: