Android提高之XML解析与生成实例详解

本文实例讲述了使用SAX来解析XML。通常来说在Android里面可以使用SAX和DOM,DOM需要把整个XML文件读入内存再解析,比较消耗内存,而SAX是基于事件驱动的处理方式,可以在各节点触发回调函数,不过SAX适合节点结构简单的XML文档,复杂的XML文档在后期的节点深度处理会有点麻烦。

本文要解析的test.xml文件如下:

<?xml version="1.0" encoding="utf-8"?>
<test>
 <title>testSAX</title>
  <content aa="1" bb="2">
   <name>hellogv</name>
   <url>http://blog.csdn.net/hellogv</url>
  </content>
</test>

解析如上XML的结果如下图所示:

使用SAX解析,需要定义SAXParserFactory(使应用程序能够配置和获取基于 SAX 的解析器以解析 XML 文档),SAXParser(从各种输入源解析 XML),XMLReader(使用回调函数读取 XML 文档),其中XMLReader是个关键。XMLReader可以为解析XML定义各种回调函数,“条件符合”的时候触发这些回调函数。

SAXParserFactory factory = SAXParserFactory.newInstance();
SAXParser parser = factory.newSAXParser();
XMLReader reader = parser.getXMLReader();
reader.setContentHandler(handler);
reader.parse(new InputSource(testSAX.this.getResources()
 .openRawResource(R.raw.test)));

在这段代码里,XMLReader就调用继承DefaultHandler的SAXHandler。DefaultHandler已实现ContentHandler, DTDHandler, EntityResolver, ErrorHandler等接口,包含常见读取XML的操作,具体请看下面的SAXHandler.java源码。

最终生成XML的结果如下图所示:

上图是读取各节点之后,使用XmlSerializer重新组合并输出XML字符串。

本文的main.xml代码如下:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:orientation="vertical" android:layout_width="fill_parent"
 android:layout_height="fill_parent">
 <Button android:layout_height="wrap_content"
 android:layout_width="fill_parent" android:id="@+id/btnSAX"
 android:text="使用SAX解析XML"></Button>
 <Button android:layout_height="wrap_content"
 android:layout_width="fill_parent" android:text="生成XML" android:id="@+id/btnOutput"></Button>
 <EditText android:text="@+id/EditText01" android:id="@+id/EditText01"
 android:layout_width="fill_parent" android:layout_height="fill_parent"></EditText>
</LinearLayout>

SAXHandler.java的源码如下:

package com.testSAX;
import java.util.ArrayList;
import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;
import android.util.Log;
public class SAXHandler extends DefaultHandler{
   private ArrayList<String> keys = new ArrayList<String>();//保存字段名称
   private ArrayList<Object> values = new ArrayList<Object>();//保存值
 @Override
 public void startDocument() throws SAXException {
  super.startDocument();
 }
 @Override
 public void endDocument() throws SAXException {
  super.endDocument();
 }
 @Override
 public void startElement(String uri, String localName, String qName,
  Attributes attributes) throws SAXException {
  //保存开始标记
  keys.add("startTag");
  values.add(localName);
  Log.e("startTag",localName);
  //保存属性值
  for ( int i = 0; i < attributes.getLength(); i++ ){
  keys.add("Attr");
  String[] str=new String[2];
  str[0]=attributes.getLocalName(i);
  str[1]=attributes.getValue(i);
  values.add(str);
  Log.e("Attr",str[0]+"="+str[1]);
  }
 }
 @Override
 public void endElement(String uri, String localName, String qName)
  throws SAXException {
  //保存结束标记
  keys.add("endTag");
  values.add(localName);
  Log.e("endTag",localName);
 }
 @Override
 public void characters(char[] ch, int start, int length)
  throws SAXException {
  String value = new String(ch, start, length);
  value = value.trim();
  if (value.length() == 0)
  return;
  keys.add("text");
  values.add(value);
  Log.e("text",value);
 }
 public ArrayList<String> GetKeys()
 {
  return keys;
 }
 public ArrayList<Object> GetValues()
 {
  return values;
 }
}

testSAX.java的源码如下:

package com.testSAX;
import java.io.StringWriter;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
import org.xml.sax.InputSource;
import org.xml.sax.XMLReader;
import org.xmlpull.v1.XmlSerializer;
import android.app.Activity;
import android.os.Bundle;
import android.util.Xml;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;

public class testSAX extends Activity {
 /** Called when the activity is first created. */
 Button btnSAX, btnOutput;
 EditText memo;
 SAXHandler handler = new SAXHandler();
 @Override
 public void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.main);
 btnSAX = (Button) this.findViewById(R.id.btnSAX);
 btnSAX.setOnClickListener(new ClickEvent());
 btnOutput = (Button) this.findViewById(R.id.btnOutput);
 btnOutput.setOnClickListener(new ClickEvent());
 memo = (EditText) this.findViewById(R.id.EditText01);

 }
 class ClickEvent implements View.OnClickListener {

 @Override
 public void onClick(View v) {
  if (v == btnSAX) {//解析XML,并保存标记,属性等值
  try {
   SAXParserFactory factory = SAXParserFactory.newInstance();
   SAXParser parser = factory.newSAXParser();
   XMLReader reader = parser.getXMLReader();
   reader.setContentHandler(handler);
   reader.parse(new InputSource(testSAX.this.getResources()
    .openRawResource(R.raw.test)));
  } catch (Exception ee) {}
  }
  else if (v == btnOutput) {//生成XML
  try {
   XmlSerializer serializer = Xml.newSerializer();
   StringWriter writer = new StringWriter();
   try {
   serializer.setOutput(writer);
   serializer.startDocument("UTF-8",true);

   for(int i=0;i<handler.GetKeys().size();i++)
   {
    if(handler.GetKeys().get(i).equals("startTag"))
    {
    serializer.startTag("", (String) handler.GetValues().get(i));
    }
    else if(handler.GetKeys().get(i).equals("Attr")){
    String[] str= (String[]) handler.GetValues().get(i);
    serializer.attribute("",str[0],str[1]);
    }
    else if(handler.GetKeys().get(i).equals("text"))
    serializer.text((String)handler.GetValues().get(i));
    else if(handler.GetKeys().get(i).equals("endTag"))
    {
    serializer.endTag("", (String) handler.GetValues().get(i));
    }
   }
   serializer.endDocument();
   String text=writer.toString();
   text=text.replace("><", ">/r/n<");
   memo.setText(text);//输出到文本框
   } catch (Exception e) {
   throw new RuntimeException(e);
   }
  } catch (Exception e) {}
  }
 }
 }
}

感兴趣的读者可以自己动手调试运行一下本实例代码,希望能对大家的Android项目开发起到参考借鉴作用。

(0)

相关推荐

  • android layout XML解析错误的解决方法

    提示: org.xmlpull.v1.XmlPullParserException: PI must not start with xml (position:unknown @1:5 in java.io.InputStreamReader@47ec2770) org.xml.sax.SAXParseException: PI must not start with xml (position:unknown xm@3:5 in java.io.InputStreamReader@43e

  • Android中使用pull解析器操作xml文件的解决办法

    一.使用Pull解析器读取XML文件 除了可以使用SAX或DOM解析XML文件之外,大家也可以使用Android内置的Pull解析器解析XML文件. Pull解析器是一个开源的java项目,既可以用于android,也可以用于JavaEE.如果用在javaEE需要把其jar文件放入类路径中,因为Android已经集成进了Pull解析器,所以无需添加任何jar文件.android系统本身使用到的各种xml文件,其内部也是采用Pull解析器进行解析的. Pull解析器的运行方式与SAX 解析器相似.

  • Android 使用Pull方法解析XML文件的方法

    Pull解析方法给应用程序完全的控制文档该怎么样被解析.Android中对Pull方法提供了支持的API,主要是 复制代码 代码如下: org.xmlpull.v1.XmlPullParser;org.xmlpull.v1.XmlPullParserFactory; 二个类,其中主要使用的是XmlPullParser,XmlPullParserFactory是一个工厂,用于构建XmlPullParser对象.应用程序通过调用XmlPullParser.next()等方法来产生Event,然后再处

  • android编程之XML文件解析方法详解(附源码)

    本文实例讲述了android编程之XML文件解析方法.分享给大家供大家参考,具体如下: 在android开发中,经常用到去解析xml文件,常见的解析xml的方式有一下三种:SAX.Pull.Dom解析方式.最近做了一个android版的CSDN阅读器,用到了其中的两种(sax,pull),今天对android解析xml的这三种方式进行一次总结. 今天解析的xml示例(channels.xml)如下: <?xml version="1.0" encoding="utf-8

  • Android中使用PULL方式解析XML文件深入介绍

    一.基本介绍 Android中极力推荐xmlpull方式解析xml. xmlpull不仅可用在Android上同样也适用于javase,但在javase环境中需自己获取xmlpull所依赖的类库,kxml2-2.3.0.jar,xmlpull_1_1_3_4c.jar. jar包下载网址 http://www.xmlpull.org/ http://kxml.sourceforge.net/ 二.例子 读取到xml的声明返回数字0 START_DOCUMENT; 读取到xml的结束返回数字1 E

  • Android开发之XML文件解析的使用

    前言  本文主要介绍在Android中怎样来解析XML文件.主要采用的是SAX机制,SAX全称为Simple API for XML,它既是一种接口,也是一个软件包.作为接口,SAX是事件驱动型XML解析的一个标准接口.XML文件解析一般有2种方法,DOM和SAX.其中DOM需要先将xml文档全部读入到电脑内存中,当文档内容太大时,该方法并不适用.SAX就比较好的解决了该问题,它是逐行解析的,可以随时中断.但是SAX的操作比较复杂.因此,这2种方法各有优缺点,看具体应用情况.在前面的文章Qt学习

  • Android使用Pull解析器解析xml文件的实现代码

    2个类:1个实体类Person.java,1个继承Activity的类 1.Person.java 复制代码 代码如下: package com.mrzhu.work_1_sax; public class Person { private String personId; private String name; private String address; private String tel; private String fax; private String email; publi

  • Android中使用sax解析xml文件的方法

    SAX是一个解析速度快并且占用内存少的xml解析器,非常适合用于Android等移动设备. SAX解析XML文件采用的是事件驱动,也就是说,它并不需要解析完整个文档,在按内容顺序解析文档的过程中,SAX会判断当前读到的字符是否合法XML 语法中的某部分,如果符合就会触发事件.所谓事件,其实就是一些回调(callback)方法,这些方法(事件)定义在ContentHandler接口.下面是一些ContentHandler接口常用的方法: startDocument():当遇到文档的开头的时候,调用

  • 基于Android XML解析与保存的实现

    解析XML文件:在Android平台上可以使用SAX.DOM和Android附带的pull解析器解析XML文件:pull解析器提供了各种事件,使用parser.next()方法进入下一个元素并触发相应事件,pull解析器产生的事件是一个数字,可以通过switch对感兴趣的事件进行处理:通过paser.nextText()方法可以获取下一个Text类型的节点的值:http://xmlpull.org/xmlpull-website/impls.shtml; 读取XMLXmlPullParser p

  • Android编程实现XML解析与保存的三种方法详解

    本文实例讲述了Android编程实现XML解析与保存的三种方法.分享给大家供大家参考,具体如下: 简介 在Android开发中,关于XML解析有三种方式,分别是: 1. SAX 基于事件的解析器,解析速度快,占用内存少.非常适合在Android移动设备中使用. 2. DOM 在内存中以树形结构存放,因此检索和更新效率会更高.但是对于特别大的文档,解析和加载整个文档将会很耗资源 3. PULL 基于事件的解析器,不同于SAX是,PULL是主动请求下一个事件,所以在可控上PULL要比SAX实用.An

  • Android 解析XML 文件的四种方法总结

    java解析xml文件四种方式 1.介绍 1)DOM(JAXP Crimson解析器) DOM是用与平台和语言无关的方式表示XML文档的官方W3C标准.DOM是以层次结构组织的节点或信息片断的集合.这个层次结构允许开发人员在树中寻找特定信息.分析该结构通常需要加载整个文档和构造层次结构,然后才能做任何工作.由于它是基于信息层次的,因而DOM被认为是基于树或基于对象的.DOM以及广义的基于树的处理具有几个优点.首先,由于树在内存中是持久的,因此可以修改它以便应用程序能对数据和结构作出更改.它还可以

随机推荐