重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇文章主要为大家展示了“Xml格式数据如何生成和解析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Xml格式数据如何生成和解析”这篇文章吧。
公司主营业务:网站制作、成都做网站、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。成都创新互联公司是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。成都创新互联公司推出钟楼免费做网站回馈大家。1. Xml格式数据的生成和解析
使用xml 作为数据交互的载体是Android中非常重要的功能,比如天气预报数据、短信备份数据、讯录数据都可以以xml
的格式通过网络传输。
XML的格式通过便签的形式书写和展示,一目了然,方便阅读和识别,如下所示:
张三 110001 male
XML的生成
如果用java代码去实现这样的一个字符串格式,可以使用到StringBuilder来进行组拼:StringBuilder sb = new StringBuilder();
//数据保存到文件 sb.append(""); sb.append(""); sb.append(" ");"); sb.append(name); sb.append(" "); sb.append(""); sb.append(number); sb.append(" "); sb.append(""); sb.append(sex); sb.append(" "); sb.append("
上面的代码虽然也可以生成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文件的所有内容以文档树方式存放在内存中,然后允许使用DOMAPI遍历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(); }
以上是“Xml格式数据如何生成和解析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!