安卓XML文件的生成和解析

序列化器生成xml文件

  • 得到xml序列化器对象

    XmlSerializer xs = Xml.newSerializer();
    
  • 给序列化器设置输出流

    File file = new File(Environment.getExternalStorageDirectory(), "backupsms.xml");
    FileOutputStream fos = new FileOutputStream(file);
    //给序列化器指定好输出流,编码为utf-8
    xs.setOutput(fos, "utf-8");
    
  • 开始生成xml文件 //enconding:指定用什么编码生成xml文件 xs.startDocument("utf-8", true); xs.startTag(null, "smss"); xs.endTag(null,"sms"); ...... //告诉序列化器,文件生成完毕 xs.endDocument();

实例:

public void click(View v){
    //使用xml序列化器生成xml文件
    //1.拿到序列化器对象
    XmlSerializer xs = Xml.newSerializer();
    //2.初始化
    File file = new File("sdcard/sms2.xml");
    try {
        FileOutputStream fos = new FileOutputStream(file);
        //enconding:指定用什么编码生成xml文件
        xs.setOutput(fos, "utf-8");
        //3.开始生成xml文件
        //enconding:指定头结点中的enconding属性的值
        xs.startDocument("utf-8", true);

        xs.startTag(null, "message");

        for (Message sms : smsList) {
            xs.startTag(null, "sms");

            xs.startTag(null, "type");
            xs.text(sms.getType());
            xs.endTag(null, "type");

            xs.startTag(null, "address");
            xs.text(sms.getAddress());
            xs.endTag(null, "address");

            xs.endTag(null, "sms");
        }   
        xs.endTag(null, "message");

        //告诉序列化器,文件生成完毕
        xs.endDocument();
    } catch (Exception e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    } 
}

pull解析xml文件

  • 先自己写一个xml文件,存一些天气信息

拿到xml文件

    InputStream is = getClassLoader().getResourceAsStream("weather.xml");

拿到pull解析器

    XmlPullParser xp = Xml.newPullParser();

开始解析

  • 拿到指针所在当前节点的事件类型

    int type = xp.getEventType();
    
  • 事件类型主要有五种

    • START_DOCUMENT:xml头的事件类型
    • END_DOCUMENT:xml尾的事件类型
    • START_TAG:开始节点的事件类型
    • END_TAG:结束节点的事件类型
    • TEXT:文本节点的事件类型
  • 如果获取到的事件类型不是END_DOCUMENT,就说明解析还没有完成,如果是,解析完成,while循环结束

    while(type != XmlPullParser.END_DOCUMENT)
    
  • 当我们解析到不同节点时,需要进行不同的操作,所以判断一下当前节点的name

    • 当解析到weather的开始节点时,new出list
    • 当解析到city的开始节点时,创建city对象,创建对象是为了更方便的保存即将解析到的文本
    • 当解析到name开始节点时,获取下一个节点的文本内容,temp、pm也是一样

      case XmlPullParser.START_TAG:
      //获取当前节点的名字
          if("weather".equals(xp.getName())){
              citys = new ArrayList<City>();
          }
          else if("city".equals(xp.getName())){
              city = new City();
          }
          else if("name".equals(xp.getName())){
              //获取当前节点的下一个节点的文本
              String name = xp.nextText();
              city.setName(name);
          }
          else if("temp".equals(xp.getName())){
              String temp = xp.nextText();
              city.setTemp(temp);
          }
          else if("pm".equals(xp.getName())){
              String pm = xp.nextText();
              city.setPm(pm);
          }
          break;
      
  • 当解析到city的结束节点时,说明city的三个子节点已经全部解析完了,把city对象添加至list

    case XmlPullParser.END_TAG:
        if("city".equals(xp.getName())){
                citys.add(city);
        }
    

函数实例:

public void click(View v){
    List<City> cityList;
    //获取到src文件夹下的资源文件
    InputStream is = getClassLoader().getResourceAsStream("weather.xml");

    //拿到pull解析器对象
    XmlPullParser xp = Xml.newPullParser();
    //初始化
    try {
        xp.setInput(is, "gbk");

        //获取当前节点的事件类型,通过事件类型的判断,我们可以知道当前节点是什么节点,从而确定我们应该做什么操作
        int type = xp.getEventType();
        City city = null;
        while(type != XmlPullParser.END_DOCUMENT){
            //根据节点的类型,要做不同的操作
            switch (type) {
            case XmlPullParser.START_TAG:
                //                  获取当前节点的名字
                if("weather".equals(xp.getName())){
                    //创建city集合对象,用于存放city的javabean
                    cityList = new ArrayList<City>();
                }
                else if("city".equals(xp.getName())){
                    //创建city的javabean对象
                    city = new City();
                }
                else if("name".equals(xp.getName())){
                    //              获取当前节点的下一个节点的文本
                    String name = xp.nextText();
                    city.setName(name);
                }
                else if("temp".equals(xp.getName())){
                    //              获取当前节点的下一个节点的文本
                    String temp = xp.nextText();
                    city.setTemp(temp);
                }
                else if("pm".equals(xp.getName())){
                    //              获取当前节点的下一个节点的文本
                    String pm = xp.nextText();
                    city.setPm(pm);
                }
                break;
            case XmlPullParser.END_TAG:
                if("city".equals(xp.getName())){
                    //把city的javabean放入集合中
                    cityList.add(city);
                }
                break;

            }

            //把指针移动到下一个节点,并返回该节点的事件类型
            type = xp.next();
        }

        for (City c : cityList) {
            System.out.println(c.toString());
        }
    } catch (Exception e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }
}

猜你喜欢

转载自blog.csdn.net/kai_zone/article/details/80230003