Xml格式数据的生成和解析

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数据的APIXmlSerializer, api 内部已经实现了对特殊字符的处理,代码如下:

try {

// 采用Androidapi面向对象的生成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解析。

 

SAXPULL解析对比

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();

}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值