android菜鸟学习笔记19----Android数据存储(三)XML文件的解析及序列化

时间:2022-04-27 10:05:47

Android内置了PULL解析器的XPP3实现,以及SAX解析器等,可以直接使用PULL或SAX解析XML,直接把JAVA中进行PULL或SAX解析的代码直接拿来用,遗忘的话,可以参考java拾遗1,2,3关于XML的解析:

如有如下XmlUtils类实现PULL方式解析XML到List和序列化List到XML:

Student实体类代码:

 package cn.csc.bean;

 public class Student {

       private String id;

       private String name;

       private String gender;

       private int age;

       public String getId() {

            return id;

       }

       public void setId(String id) {

            this.id = id;

       }

       public String getName() {

            return name;

       }

       public void setName(String name) {

            this.name = name;

       }

       public String getGender() {

            return gender;

       }

       public void setGender(String gender) {

            this.gender = gender;

       }

       public int getAge() {

            return age;

       }

       public void setAge(int age) {

            this.age = age;

       }

       public Student() {

            super();

       }

       public Student(String id, String name, String gender, int age) {

            super();

            this.id = id;

            this.name = name;

            this.gender = gender;

            this.age = age;

       }

       @Override

       public String toString() {

            return "["+id+","+name+","+gender+","+age+"]";

       }

 }

XmlUtils类的代码:

 public class XmlUtils {

       public static void serialize(Context context, String filename, List<Student> list){

            try {

                  XmlPullParserFactory factory = XmlPullParserFactory.newInstance();

                  XmlSerializer serializer = factory.newSerializer();

                  serializer.setOutput(context.openFileOutput(filename, Context.MODE_PRIVATE), "utf-8");

                  serializer.startDocument("utf-8", true);

                  serializer.startTag(null, "students");

                  for(Student s:list){

                       serializer.startTag(null, "student");

                       serializer.attribute(null, "id", s.getId());

                       serializer.startTag(null, "name");

                       serializer.text(s.getName());

                       serializer.endTag(null, "name");

                       serializer.startTag(null, "gender");

                       serializer.text(s.getGender());

                       serializer.endTag(null, "gender");

                       serializer.startTag(null, "age");

                       serializer.text(s.getAge()+"");

                       serializer.endTag(null, "age");

                       serializer.endTag(null, "student");

                  }

                  serializer.endTag(null, "students");

                  serializer.endDocument();

            } catch (Exception e) {

                  // TODO Auto-generated catch block

                  e.printStackTrace();

            }

       }

       public static List<Student> parse(Context context, String filename){

            List<Student> list = new ArrayList<Student>();

            try {

                  XmlPullParserFactory factory = XmlPullParserFactory.newInstance();

                  XmlPullParser parser = factory.newPullParser();

                  parser.setInput(context.openFileInput(filename), "utf-8");

                  Student s = null;

                  int eventType = parser.getEventType();

                  while(eventType != XmlPullParser.END_DOCUMENT){

                       if(eventType == XmlPullParser.START_TAG){

                             String tag = parser.getName();

                             if(tag.equals("student")){

                                   s = new Student();

                                   s.setId(parser.getAttributeValue(0));

                             }else if(tag.equals("name")){

                                   s.setName(parser.nextText());

                             }else if(tag.equals("gender")){

                                   s.setGender(parser.nextText());

                             }else if(tag.equals("age")){

                                   s.setAge(Integer.parseInt(parser.nextText()));

                             }

                       }else if(eventType == XmlPullParser.END_TAG && parser.getName().equals("student")){

                             list.add(s);

                       }

                       eventType = parser.next();

                  }

                  for(Student stu : list){

                       Log.i("XML_PARSER",stu.toString());

                  }

            } catch (Exception e) {

                  // TODO Auto-generated catch block

                  e.printStackTrace();

                  return null;

            }

            return list;

       }

 }

使用Android Juit分别测试这两个方法:

 public class XmlTest extends AndroidTestCase {

       public void testSerializer(){

            List<Student> list = new ArrayList<Student>();

            for(int i=0; i<20; i++){

                  list.add(new Student(i+"","dqrcsc","male",25));

            }

            XmlUtils.serialize(getContext(), "students.xml", list);

       }

       public void testParser(){

            XmlUtils.parse(getContext(), "students.xml");

       }

 }

运行结果:

android菜鸟学习笔记19----Android数据存储(三)XML文件的解析及序列化

android菜鸟学习笔记19----Android数据存储(三)XML文件的解析及序列化

以上代码,除了获取Context上下文对象外,与Java项目中对XML的PULL解析是完全一样的。

实际上,Andoid在android.util包中还提供了一个Xml类,实现了对XML解析、序列化操作的封装,在使用时,可以相对简单一点:

android菜鸟学习笔记19----Android数据存储(三)XML文件的解析及序列化

这五个静态方法分别简化了PULL解析器、PULL序列化器、SAX解析的操作:

之前通过工厂类实例获取PULL序列化器的操作,可以从:

 XmlPullParserFactory factory = XmlPullParserFactory.newInstance();

 XmlSerializer serializer = factory.newSerializer();

简化为:

XmlSerializer serializer = Xml.newSerializer();

通过工厂类实例获取PULL解析器的操作,也可以从:

 XmlPullParserFactory factory = XmlPullParserFactory.newInstance();

 XmlPullParser parser = factory.newPullParser();

简化为:

XmlPullParser parser = Xml.newPullParser();

同样的,SAX解析也简化为直接调用Xml的parse()静态方法,这里就不说明了。

android菜鸟学习笔记19----Android数据存储(三)XML文件的解析及序列化的更多相关文章

  1. 把数据存储到 XML 文件

    通常,我们在数据库中存储数据.不过,如果希望数据的可移植性更强,我们可以把数据存储 XML 文件中. 创建并保存 XML 文件 如果数据要被传送到非 Windows 平台上的应用程序,那么把数据保存在 ...

  2. android菜鸟学习笔记17----Android数据存储&lpar;一&rpar;文件读写

    假如有如下需求,要求能够记录用户输入的用户名和密码,下次登录时,能直接获取之前保存的用户名密码,并在相应的EditText中显示. 要保存用户输入的数据,最先想到的应该就是文件读写了. 通过对andr ...

  3. android菜鸟学习笔记18----Android数据存储&lpar;二&rpar;SharedPreferences

    数据存储的方式,有比直接文件读写更加简便的方式,那就是操作SharedPreferences. SharedPreferences一般用于存储用户的偏好设定,暂时不支持多进程操作. SharedPre ...

  4. android菜鸟学习笔记24----与服务器端交互&lpar;一&rpar;使用HttpURLConnection和HttpClient请求服务端数据

    主要是基于HTTP协议与服务端进行交互. 涉及到的类和接口有:URL.HttpURLConnection.HttpClient等 URL: 使用一个String类型的url构造一个URL对象,如: U ...

  5. android菜鸟学习笔记23----ContentProvider&lpar;三&rpar;利用内置ContentProvider监听短信及查看联系人

    要使用一个ContentProvider,必须要知道的是它所能匹配的Uri及其数据存储的表的结构. 首先想办法找到访问短信及联系人数据的ContentProvider能接受的Uri: 到github上 ...

  6. android菜鸟学习笔记21----ContentProvider&lpar;一&rpar;ContentProvider的简单使用

    ContentProvider是Android四大组件之一,它用来封装数据,并通过ContentResolver接口将数据提供给其他应用.只有当需要在多个应用之间共享数据时才会用到ContentPro ...

  7. android菜鸟学习笔记16----Android项目打包安装过程&lpar;Run as Android Application&rpar;

    右击项目名称,Run as Android Appication之后,Android项目打包安装过程: 1.打包生成.apk文件: 1)把源码中的.java文件编译生成.class文件 2)将所有的. ...

  8. android菜鸟学习笔记14----Android控件&lpar;三&rpar; ListView的简单使用

    MVC模式: MVC的基本原理就是通过Controller连接View和Model.当View中所显示的数据发生变化时,会通知Controller,然后由Controller调用Model中的相关方法 ...

  9. android菜鸟学习笔记10----Intent及&lt&semi;intent-filter&gt&semi;

    关于Bundle: 注意到Activity的onCreate()方法的签名是protected void onCreate(Bundle savedInstanceState),其参数是一个Bundl ...

随机推荐

  1. SQLite剖析之C&sol;C&plus;&plus;接口

    前言 SQLite3是SQLite一个全新的版本,它虽然是在SQLite2的代码基础之上开发的,但是使用了和之前的版本不兼容的数据库格式和API.SQLite3是为了满足以下的需求而开发的:支持UTF ...

  2. 黄聪:Discuz自制模板带jquery时与discuz本身冲突解决办法

    由于JQuery的效果很好,在制作模板时难免会用到各种jquery效果.可是做过模板的人就会发现加上自己的juery代码后,discuz自带的一些下拉功能就不可以使用了,其实原因就是discuz和JQ ...

  3. NPOI导出word,以及对table的一些设置

    参考网址:http://www.aiuxian.com/article/p-1970779.html NPOI版本:2.1.3.1 最终效果图: 代码: /// <summary> /// ...

  4. stm32l053r8 nucelo板的串口实验

    stm32cubel0的HAL驱动实例中,基于stm32l53R8  nucelo板的官方串口通讯例程,是使用USART1实现在两块stm32l053r8 nucelo板间通讯.而在实际中,笔者手中只 ...

  5. JS实用小函数 数据是否合法或存在 获取当前日期时间

    1.判断数据是否合法或存在 //判断数据是否合法或存在 function isNotNull(data) { if(data === "" || data === undefine ...

  6. xml方式将dataset导出excel

    using System;using System.Collections;using System.Collections.Generic;using System.Data;using Syste ...

  7. volatile关键字的作用

    引言:以前只是看过介绍volatile的文章,对其的理解也只是停留在理论的层面上,由于最近在项目当中用到了关于并发方面的技术,所以下定决心深入研究一下java并发方面的知识.网上关于volatile的 ...

  8. 创建第一次C语言程序

    在这里我以VS2015为例,做演示.为什么要去演示怎样创建项目尼,因为我写第一个程序时,不知道该怎样用VS创建我的第一个应用程序. 第一步:打开VS环境如下 第二步:在开始出点击“新建项目”或在右上角 ...

  9. 【原创】MySQL Replay线上流量压测工具

    一. 背景 去年做过一次mysql trace 重放的测试,由于performance schema本身采集样本的长度等限制,实际回放的成功率比较低. 最近找到一款开源的工具,基于TCPCopy实现了 ...

  10. 百度Android在线语音识别SDK用法

    百度Android语音识别SDK分在线与离线两种,这篇文章介绍在线SDK的用法. 在线SDK是以JAR包和动态链接库形式公布和使用,能够从百度开放云平台站点中下载SDK及使用说明文档. title=d ...