Android平台基于Pull方式对XML文件解析与写入方法详解

本文详细讲述了Android平台基于Pull方式对XML文件解析与写入方法。分享给大家供大家参考,具体如下:

XML技术在跨平台的情况下的数据交互中得到了广泛的应用,假如我们需要开发一个Android应用程序,需要同服务器端进行数据交互,通过XML文件可以很方便的在Android平台和服务器之间进行数据传输,具体实现涉及到对XML文件进行解析及写入的技术。本文实现在Android平台上基于Pull方式对XML文件解析的技术。

XmlPullParser是一个Java实现的开源API包(源码下载地址http://www.xmlpull.org/),实现了pull方式解析xml文件的方法, Android SDK中包含了该API,使用时需要导入以下三个包:

import org.xmlpull.v1.XmlPullParser;//包含解析XML文件类的包
import org.xmlpull.v1.XmlPullParserException;//处理异常
importorg.xmlpull.v1.XmlSerializer;//包含写入XML文件类的包

我们以SQLite数据库课堂练习中的数据类People为例,People类有4个属性:ID,Name,Age,Height,假设有一条测试数据ID=1,Name=”杜甫”,Age=30,Height=1.75,

在XML文件中对应的数据项元素如下:

<peopleinfo>
  <peopletag="item1">
    <id>1</id>
    <name>杜甫</name>
    <age>30</age>
    <height>1.75</height>
</people>
</peopleinfo>

1. 使用XmlPullParser对该文件解析

首先需要初始化一个XmlPullParser对象parser,R.xml.peopleinfo为文件peopleinfo.xml在项目中的标识,读入该文件后一步一步对文件中的元素进行解析。

XmlPullParser parser= getResources().getXml(R.xml.peopleinfo);

XmlPullParser的相关函数及说明如下:


相关函数或变量


说明


示例


XmlPullParser.START_DOCUMENT


文档开始标识,根元素


<peopleinfo>


XmlPullParser.END_DOCUMENT


文档结束标识


</peopleinfo>


XmlPullParser.START_TAG


元素开始标识


<people>


XmlPullParser.END_TAG


元素结束标识


</people>


getEventType()


获取当元素的类型 (如START_TAG, END_TAG, TEXT, etc.)


如<peopleinfo>

的类型为START_DOCUMENT


next()


获取下一个待解析元素


事件表示<>括号中的一个项


getName()


获取当前元素的名字


如读取到<age>,返回值为”age”


nextText()


返回当前元素所对应的文本值


如事件为<height>时,返回1.75


getAttributeName(int index)


获取当前元素中属性名


如tag


getAttributeValue(int index)


获取当前元素中属性的值


"item1"

解析步骤:

1)    初始化parser,指定xml文件
2)    读取文档开始标识,根元素<peopleinfo>
3)    读取数据项元素开始标识, <people>
    a)    读取数据项元素的属性,tag="item1"
    b)    读取数据项的子元素,id,name,age,height
4)    一个数据项结束,</people>,保存该数据项的结果
5)    读取文档结束标识,</peopleinfo>

2. 使用XmlSerializer对写XML文件

写入XML文件的过程:先初始化一个XmlSerializer对象serializer,设置输出的Writer对象,然后数据写入serializer中,再将该对象通过Writer写入文件。

XmlSerializer serializer = Xml.newSerializer();
serializer.setOutput(writer);
//…
writer.flush()

XmlSerializer的相关函数及说明如下:


相关函数


说明


示例


setOutput(Writer writer)


设置输出的Writer对象


 


startDocument(String encoding, Boolean standalone);


写入XML文件的起始标识语句,必须在setOutput后被调用


<?xml version="1.0" encoding="UTF-8" standalone="yes" ?>


startTag(String namespace, String name);


写入开始元素标识


如<people>,<age>


attribute(String namespace, String name, String value); 


 


如tag=”people1”


text(String text)


写入元素值


如:杜甫


endTag(String namespace, String name)


写入元素结束标识


如</people>,</age>


endDocument(); 


写入文档结束标记


 

写入步骤:

1) 初始化serializer
2) 设置Writer对象writer
3) 写入文档开始标记<?xml version="1.0" encoding="UTF-8"standalone="yes" ?>
4) 写入根元素<peopleinfo>
5) 写入数据项元素<people>
    a)  写入数据项属性tag=”people1”
    b)  写入数据项子元素,id,name,age,height
6) 写入数据项元素结束符</people>
7) 写入根元素结束符</peopleinfo>
8) 写入文档结束符
9) 通过writer将数据写入文件,writer.flush()
10) 关闭writer对象

实现工具类XmlPullHelper,提供对XML文件解析和写入的

1. 具体实现,代码如下:

package aaron.android.SQLiteDamon;
import java.io.IOException;
import java.io.Writer;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map;
import org.xmlpull.v1.XmlPullParser;
import org.xmlpull.v1.XmlPullParserException;
import org.xmlpull.v1.XmlSerializer;
import android.util.Log;
public class XmlPullHelper {
  private XmlPullParser parser;
  private XmlSerializer serializer;
  private ArrayList<Map<String, Object>> contents=new ArrayList<Map<String,Object>>();
  private Map<String,Object> map=null;
  public XmlPullHelper(XmlPullParser parser,XmlSerializer serial){
    this.parser=parser;
    this.serializer = serial;
  }
  /**
   * 将xml文件中的所有节点的数据解析后保存在一个ArrayList中返回
   * @param nodeName:数据项的名称,这里为"people"
   * @param attr:数据项的属性,如id,name,age,height
   * @return 解析该xml文件数据的结果
   * @throws XmlPullParserException
   * @throws IOException
   */
  public ArrayList<Map<String,Object>> xmlPull(String nodeName,String[] attr) throws XmlPullParserException, IOException{
    //循环读取所有的元素
    while(parser.next()!=XmlPullParser.END_DOCUMENT){
      switch(parser.getEventType()){
        case XmlPullParser.START_DOCUMENT:
          break;
        case XmlPullParser.START_TAG:{  //元素开始标识
          //判断是否为所需要的数据项,如果是,在初始化一个map用于保存该数据项的值
          if(parser.getName()!=null&&parser.getName().equals(nodeName)){
            map=new HashMap<String, Object>();
            //循环读取该元素中所有的属性
            for(int j=0;j<parser.getAttributeCount();j++)
              map.put(parser.getAttributeName(j), parser.getAttributeValue(j));//添加属性的值,如tag="item1"
          }
          else if(map!=null){
            for(int i=0;i<attr.length;i++){
              if(parser.getName()!=null&&parser.getName().equals(attr[i])){//添加子元素的值,如<name>张三</name>
                map.put(attr[i],parser.nextText());
              }
            }
          }
          break;
        }
        case XmlPullParser.END_TAG: {//元素结尾标识
          //判断是否为一个数据项的结束,如果是,将该数据项的数据添加到数据集contents中
          if(parser.getName().equals(nodeName)&&map!=null){
            contents.add(map);
            map=null;
          }
          break;
        }
      }
    }
    return contents;
  }
  /**
   * 将给定的数据集写入XML文件
   * @param fileName: 根元素名,默认设为跟文件名相同,如"peopleinfo"
   * @param nodeName: 数据项名 如"people"
   * @param attr: 数据项的属性 如id,name,age,height
   * @param con: 待写入的数据集
   * @throws XmlPullParserException
   * @throws IOException
   */
  public void xmlWrite(String fileName,String nodeName,String[] attr,ArrayList<Map<String,Object>> con) throws XmlPullParserException, IOException{
    serializer.startDocument("UTF-8", true);
    serializer.startTag(null, fileName);//开始根元素标签<peopleinfo>
    for(int i=0;i<con.size();i++)
    {
      //开始元素标签<people>
      serializer.startTag(null, nodeName);
      //标签people属性
      serializer.attribute(null, "tag", "people"+i);
      //循环将子节点写入元素id,name,age,height
      for(int j=0;j<attr.length;j++)
      {
        serializer.startTag(null, attr[j]);
        serializer.text(con.get(i).get(attr[j]).toString());
        serializer.endTag(null, attr[j]);
      }
      //结束标签</people>
      serializer.endTag(null, nodeName);
    }
    //结束标签</peopleinfo>
    serializer.endTag(null, fileName);
    //结束文档标记
    serializer.endDocument();
  }
}

1. 使用该工具类XmlPullHelper具体实现

//定义数据集对象contents用于保存从XML文件中读取的数据
ArrayList<Map<String, Object>> contents = null;
//将数据写入XML文件,并保存到SD卡中
if(Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)){
    File sdCardDir = Environment.getExternalStorageDirectory();//获取SDCard目录
    File saveFile = new File(sdCardDir, "peopleinfo.xml");
    FileWriter w=new FileWriter(saveFile);
    XmlSerializer serializer = Xml.newSerializer();
    XmlPullHelper xHelper=new XmlPullHelper(null,serializer);
    //待写入的子元素标签
    String []items={"id","name","age","height"};
    //将Writer对象传递给 serializer
    serializer.setOutput(w);
    xHelper.xmlWrite("peopleinfo", "people", items, contents);//调用写入方法
    w.flush(); //将serializer中数据写入文件
    w.close();
}
//读XML文件,解析并保存在数据集contents
XmlPullParser parser = getResources().getXml(R.xml.peopleinfo);
XmlPullHelper xHelper=new XmlPullHelper(parser,null);
String []items={"id","name","age","height"};
try{
  contents=xHelper.xmlPull("people", items);//调用解析方法
}
catch(Exception e){
  Log.e("XmlPullParser",e.getMessage(),e);
}

Android SDK内置了Pull解释器,使用XmlPullParser比较方便,解析XML文件的技术还有很多种,如 SAX和DOM,还需要更多的学习。

更多关于Android相关内容感兴趣的读者可查看本站专题:《Android操作XML数据技巧总结》、《Android编程之activity操作技巧总结》、《Android资源操作技巧汇总》、《Android文件操作技巧汇总》、《Android操作SQLite数据库技巧总结》、《Android操作json格式数据技巧总结》、《Android数据库操作技巧总结》、《Android编程开发之SD卡操作方法汇总》、《Android开发入门与进阶教程》、《Android视图View技巧总结》及《Android控件用法总结》

希望本文所述对大家Android程序设计有所帮助。

(0)

相关推荐

  • Android编程使用pull方式解析xml格式文件的方法详解

    本文实例讲述了Android编程使用pull方式解析xml格式文件的方法.分享给大家供大家参考,具体如下: 上次已经说过使用Android sax解析xml,实际上还可以使用pull解析xml.这样的方式效率也是比较高的.pull不仅可以在Android上使用也可以用在javaee里面,需要的就是pull的jar包.这次的xml也使用上次的那个,如下所示 <?xml version="1.0" encoding="UTF-8"?> <persons

  • Android pull解析xml的实现方法

    Android pull解析xml的实现方法 资源文件: persons.xml <?xml version="1.0" encoding="utf-8" standalone="yes" ?> <persons> <person id="101"> <name>jame</name> <age>18</age> </person>

  • Android XmlPullParser 方式解析 Xml 文档

    Android XmlPullParser 方式解析 Xml 文档 xml 文件格式 <?xml version="1.0" encoding="UTF-8"?> <persons> <person id="1"> <name>张三</name> <age>22</age> </person> <person id="2"&g

  • android4.0混淆XmlPullParser报错原因分析解决

    复制代码 代码如下: [2013-05-20 17:30:52 - danielinbiti] Proguard returned with error code 1. See console [2013-05-20 17:30:52 - danielinbiti] Note: there were 67 duplicate class definitions. [2013-05-20 17:30:52 - danielinbiti] Warning: library class android

  • Android编程解析XML文件的方法详解【基于XmlPullParser】

    本文实例讲述了Android编程解析XML文件的方法.分享给大家供大家参考,具体如下: 前言 在学习Android的Framework层源码时,Android大量的使用XmlPullParser来解析xml文件的源码.因此,这里也顺道介绍一下XmlPullParser的使用. XML XML(eXtensible Markup Language)中文名为可扩展标记语言.标记指计算机所能理解的信息符号,通过此种标记,计算机之间可以处理包含各种信息的文章等. 用途 XML设计用了传送及携带数据信息,

  • 详解Android之解析XML文件三种方式(DOM,PULL,SAX)

    1.xml文件代码 <?xml version="1.0" encoding="UTF-8" ?> <%@ page language="java" contentType="text/xml; charset=UTF-8" pageEncoding="UTF-8"%> <%@ taglib uri="http://java.sun.com/jsp/jstl/core

  • Android解析XML(PULL)展示到ListView

    Android解析XML展示到ListView运行后的效果图如下: 服务端的请求页面 <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://

  • 实例解析Android中使用Pull解析器解析XML的方法

    1.Pull简介 Pull解析器是Android系统内置的的,Pull解析器与SAX解析器类似,他提供了类似的事件,如开始元素和介绍元素的事件,使用parser.next()可以进入下一个元素并触发相应的事件,然后进行相应的处理,当元素开始解析时,调用perser.nextText()方法就可以获取到下一个Text类型元素的值. 2.pull特点 (1)简单的结构,一个接口,一个另外,一个工厂组成了Pull解析器 (2)简单易用,Pull解析器只有一个重要的方法next(),他被用来检索下一个事

  • Android平台基于Pull方式对XML文件解析与写入方法详解

    本文详细讲述了Android平台基于Pull方式对XML文件解析与写入方法.分享给大家供大家参考,具体如下: XML技术在跨平台的情况下的数据交互中得到了广泛的应用,假如我们需要开发一个Android应用程序,需要同服务器端进行数据交互,通过XML文件可以很方便的在Android平台和服务器之间进行数据传输,具体实现涉及到对XML文件进行解析及写入的技术.本文实现在Android平台上基于Pull方式对XML文件解析的技术. XmlPullParser是一个Java实现的开源API包(源码下载地

  • 对python修改xml文件的节点值方法详解

    这是我的xml文件结构 <?xml version='1.0' encoding='utf-8'?> <annotation> <folder>JPEGImages</folder> <filename>train_2018-05-08_1000.jpg</filename> <path>D:\all_data\2018-05-08\JPEGImages\train_2018-05-08_1000.jpg</path

  • Java操作Excel文件解析与读写方法详解

    目录 一.概述 二.Apache POI 三.XSSF解析Excel文件 1.Workbook(Excel文件) 2.Sheet(工作簿) 3.Row(数据行) 4.Cell(单元格) 四.超大Excel文件读写 1.使用POI写入 2.使用EasyExcel 一.概述 在应用程序的开发过程中,经常需要使用 Excel 文件来进行数据的导入或导出.所以,在通过Java语言实现此 类需求的时候,往往会面临着Excel文件的解析(导入)或生成(导出). 在Java技术生态圈中,可以进行Excel文件

  • android编程之xml文件读取和写入方法

    本文实例讲述了android编程之xml文件读取和写入方法.分享给大家供大家参考.具体分析如下: 一.环境: 主机:WIN8 开发环境:Eclipse 二.说明: 1.打开sd卡中的xml文件,如果不存在,这新建一个,并写入默认配置 2.读取xml文件 三.xml文件格式: <?xml version="1.0" encoding="UTF-8" standalone="true"?> -<config> <titl

  • Android中gson、jsonobject解析JSON的方法详解

    JSON的定义: 一种轻量级的数据交换格式,具有良好的可读和便于快速编写的特性.业内主流技术为其提供了完整的解决方案(有点类似于正则表达式 ,获得了当今大部分语言的支持),从而可以在不同平台间进行数据交换.JSON采用兼容性很高的文本格式,同时也具备类似于C语言体系的行为. JSON对象: JSON中对象(Object)以"{"开始, 以"}"结束. 对象中的每一个item都是一个key-value对, 表现为"key:value"的形式, ke

  • SpringBoot整合MinIO实现文件上传的方法详解

    目录 前言 1. MinIO 简介 2. MinIO 安装 3. 整合 Spring Boot 4. 配置nginx 5. 小结 前言 现在 OSS 服务算是一个基础服务了,很多云服务厂商都有提供这样的服务,价格也不贵,松哥自己的网站用的就是类似的服务. 不过对于中小公司来说,除了购买 OSS 服务之外,也可以自己搭建专业的文件服务器,自己搭建专门的文件服务器的话,曾经比较专业的做法是 FastDFS,松哥之前也专门为之录过视频发在 B 站上,感兴趣的小伙伴可以自行查看.不过 FastDFS 搭

  • Java Spring MVC 上传下载文件配置及controller方法详解

    下载: 1.在spring-mvc中配置(用于100M以下的文件下载) <bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"> <property name="messageConverters"> <list> <!--配置下载返回类型--> <bean class="or

  • 基于Python的Post请求数据爬取的方法详解

    为什么做这个 和同学聊天,他想爬取一个网站的post请求 观察 该网站的post请求参数有两种类型:(1)参数体放在了query中,即url拼接参数(2)body中要加入一个空的json对象,关于为什么要加入空的json对象,猜测原因为反爬虫.既有query参数又有空对象体的body参数是一件脑洞很大的事情. 一开始先在apizza网站 上了做了相关实验才发现上面这个规律的,并发现该网站的请求参数要为raw形式,要是直接写代码找规律不是一件容易的事情. 源码 import requests im

  • python文件处理fileinput使用方法详解

    这篇文章主要介绍了python文件处理fileinput使用方法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 一.介绍 fileinput模块可以对一个或多个文件中的内容进行迭代.遍历等操作,我们常用的open函数是对一个文件进行读写操作. fileinput模块的input()函数比open函数更高效和好用,体现在: input()函数生成一个迭代器,保证了在遇到大文件的读取时不会占用太大的内存. 用fileinput对文件进行循环遍历

  • JS实现单个或多个文件批量下载的方法详解

    目录 前言 单个文件Download 方案一:location.href or window.open 方案二:通过a标签的download属性 方案三:API请求 多个文件批量Download 方案一:按单个文件download方式,循环依次下载 方案二:前端打包成zip download 方案三:后端压缩成zip,然后以文件流url形式,前端调用download 总结 前言 在前端Web开发中,下载文件是一个很常见的需求,也有一些比较特殊的Case,比如下载文件请求是一个POST.url不是

随机推荐