`

Pull解析器

阅读更多

1,

package com.service;

import java.io.InputStream;
import java.io.OutputStream;
import java.util.ArrayList;
import java.util.List;

import org.xmlpull.v1.XmlPullParser;
import org.xmlpull.v1.XmlPullParserFactory;
import org.xmlpull.v1.XmlSerializer;

import android.util.Xml;

import com.model.Person;

/**
 * 解析基类
 * @author HJ
 *
 */
public class BaseParser {
	
	/** Pull解析器解析XML文件数据
	 * @param xml 待解析数据以InputStream方式传入
	 * @return
	 * @throws Exception
	 */
	public List<Person> getPersons(InputStream xml)throws Exception{
		List<Person> persons = null;
		Person person = null;
		XmlPullParser pull = Xml.newPullParser();   
		//XmlPullParser pull = XmlPullParserFactory.newInstance().newPullParser();  //通过XMLPullParserFactory工厂类获取Pull解析器
		pull.setInput(xml, "UTF-8");//为pull解析器设置需要解析的xml数据
		int event = pull.getEventType();
		while(event!=XmlPullParser.END_DOCUMENT){
			switch (event) {	
			case XmlPullParser.START_DOCUMENT:
				persons = new ArrayList<Person>();
				break;
			case XmlPullParser.START_TAG:
				if ("person".equals(pull.getName())) {
					person = new Person();
					String IDcard = pull.getAttributeValue(0);
					person.setIDCard(IDcard);
				}
				if ("name".equals(pull.getName())) {
					String name = pull.nextText();
					person.setName(name);
				} 
				if ("sex".equals(pull.getName())) {
					String sex = pull.nextText();
					person.setSex(sex);
				}
				if ("address".equals(pull.getName())) {
					String address = pull.nextText();
					person.setAddress(address);
				}
				break;
			case XmlPullParser.END_TAG:
				if ("person".equals(pull.getName())) {
					persons.add(person);
					person = null;
				}
				break;
			}
			
			event = pull.next();
		}
		return persons;
	}
	/**
	 * 对象方式保存数据到XML文件
	 * @param persons 待保存数据集合
	 * @param out 输出流
	 * @throws Exception
	 */
	public void saveToXML(List<Person> persons,OutputStream out)throws Exception{
		XmlSerializer serializer = Xml.newSerializer();
		serializer.setOutput(out, "UTF-8");
		serializer.startDocument("UTF-8", true);
		serializer.startTag(null, "persons");
		for(Person person:persons){
			serializer.startTag(null,"person");
			serializer.attribute(null,"IDCard", person.getIDCard());
			//name 节点
			serializer.startTag(null,"name");
			serializer.text(person.getName());
			serializer.endTag(null, "name");
			//sex 节点
			serializer.startTag(null, "sex");
			serializer.text(person.getSex());
			serializer.endTag(null, "sex");
			//address 节点
			serializer.startTag(null, "address");
			serializer.text(person.getAddress());
			serializer.endTag(null, "address");
			
			serializer.endTag(null, "person");
		}
		serializer.endTag(null,"persons");
		serializer.endDocument();
		out.flush();
		out.close();
	}
	//
}

 2,persons.xml

<?xml version="1.0" encoding="UTF-8"?>
<persons>
    <person IDcard="215x">
        <name>Mr.Chiang</name>
        <sex>Gentleman</sex>
        <address>China</address>
    </person>
    <person IDcard="9527">
        <name>Mrs.Chen</name>
        <sex>Lady</sex>
        <address>France</address>
    </person>
</persons>

 3,测试类

	package com.emolay.test;
	
	import java.io.File;
	import java.io.FileOutputStream;
	import java.io.InputStream;
	import java.util.List;
	
	import com.model.Person;
	import com.service.BaseParser;
	
	import android.test.AndroidTestCase;
	import android.util.Log;
	
	public class BaseParserTest extends AndroidTestCase {
		private static final String TAG = "BaseParserTest";
	
		/**
		 * test getPersons method
		 * 
		 * @throws Exception
		 */
		public void testGetPersons() throws Exception {
			InputStream xml = this.getClass().getClassLoader()
					.getResourceAsStream("persons.xml");
			BaseParser baseParser = new BaseParser();
			List<Person> persons = baseParser.getPersons(xml);
			for (Person p : persons) {
				Log.i(TAG, p.getIDCard());
			}
		}
	
		/**
		 * test saveToXML method
		 * 
		 * @throws Exception
		 */
		public void testSaveToXML() throws Exception {
			InputStream xml = this.getClass().getClassLoader()
					.getResourceAsStream("persons.xml");
			BaseParser baseParser = new BaseParser();
			List<Person> persons = baseParser.getPersons(xml);
			File fileXML = new File(getContext().getFilesDir(), "NewPersons.xml");
			FileOutputStream out = new FileOutputStream(fileXML);
			baseParser.saveToXML(persons, out);
		}
	}

 

分享到:
评论

相关推荐

    使用pull解析器解析和生成xml文件

    本文将深入探讨如何使用Pull解析器来解析和生成XML文件,特别关注Android环境下的应用。 ### Pull解析器概述 Pull解析器是一种事件驱动型的XML解析器,它允许开发者通过一系列的事件来读取和解析XML文档。与SAX...

    pull解析器的使用

    而Pull解析器则是一种轻量级的、事件驱动的XML解析方式,特别适合于资源有限的移动设备或嵌入式系统。本文将详细介绍如何使用Pull解析器来处理XML数据,并结合Junit进行测试,确保解析和生成XML文件的正确性。 首先...

    使用Pull解析器读取XML文件和生成XML文件

    本篇文章将深入探讨如何使用Pull解析器来读取XML文件,以及如何生成XML文件。Pull解析器是一种轻量级的解析方式,它允许程序在解析XML时按需获取数据,而不需要一次性加载整个文档到内存,从而提高了效率和资源利用...

    pull解析器

    【Pull解析器】是一种在Android开发中用于解析XML数据的高效工具。相比于DOM解析和SAX解析,Pull解析器更加轻量级,因为它不需要将整个XML文档加载到内存中,而是通过事件驱动的方式逐行读取和解析XML,从而节省内存...

    pull解析器通用解析XML与生成XML

    标题中的“pull解析器通用解析XML与生成XML”是指一种基于Pull解析模型处理XML文档的技术。在Android系统中,XML Pull解析器是一个轻量级、高效的解析XML文档的工具,它不需要DOM(Document Object Model)或者SAX...

    采用pull解析器解析和生成xml内容

    在Android开发中,由于其轻量级和高效的特点,Pull解析器成为了处理XML数据的一种常见方法。本篇文章将深入探讨如何在Android环境中使用内置的Pull解析器来解析和生成XML内容。 首先,我们需要理解什么是Pull解析器...

    pull解析器解析XML工具类

    在Android开发中,由于其轻量级和低内存占用,Pull解析器常常被用来解析XML文档,尤其是在处理大数据量时,相比DOM和SAX解析器更为高效。 Pull解析器是一种事件驱动的解析方式,它不会一次性加载整个XML文档到内存...

    使用Android自带的XML解析器PULL解析器简单的解析xml

    Android系统提供了一种轻量级的XML解析方式——PULL解析器(Pull Parser),它适用于处理大型XML文档,因为它不需要像DOM解析器那样一次性加载整个XML文档到内存中。PULL解析器通过事件驱动的方式,按需解析XML文档...

    Pull解析器解析和生成XML内容

    为了处理XML文档,我们通常会使用解析器,而Pull解析器是一种轻量级、低内存占用的解析方式,特别适合移动设备或者资源有限的环境。本文将详细介绍如何使用Pull解析器来解析和生成XML内容,这对于初学者来说是一个很...

    android下的pull解析器解析和生成xml文件

    为了有效地处理XML文档,Android提供了多种解析机制,其中一种就是Pull解析器(PULL Parser)。本篇将深入探讨Android下Pull解析器的使用,以及如何利用它来解析和生成XML文件。 一、Android Pull解析器简介 Pull...

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

    在Android开发中,处理XML数据是一项常见的任务,而Android提供了内置的Pull解析器来高效地读取和生成XML文件。本文将详细介绍如何使用Pull解析器来操作XML。 首先,我们来理解什么是Pull解析器。Pull解析器是一种...

    Android中采用Pull解析器读取和生成xml内容案例

    Pull解析器(XMLPullParser)是Android SDK提供的一种轻量级、低内存占用的XML解析方式,它允许开发者顺序处理XML文档,而无需加载整个文档到内存。本案例将深入探讨如何使用Pull解析器读取和生成XML内容。 首先,...

    java_pull解析器使用包kxml2_xmlpull

    java_pull解析器使用包kxml2_xmlpull,包括gson-2.8.2.jar;kxml2-2.3.0.jar;xmlpull_1_1_3_4c.jar;xmlpull-1.1.3.1,jar;xstream-1.4.10.jar

    android xml pull解析示例

    XML Pull解析器是基于事件驱动的解析方式,它会触发一系列事件(如开始标签、结束标签、文本数据等),开发者可以注册监听这些事件,从而实现对XML文档的解析。这种方式既节省内存又提高效率,特别适合处理大型XML...

    android之Pull解析XML文件

    本文将深入探讨如何在Android中使用Pull解析器来处理XML文件,这是一种高效且节省资源的方式。 Pull解析器是Android提供的一个API,它允许应用程序通过事件驱动的方式解析XML文档。与SAX解析器类似,Pull解析器不...

    Android中,使用SAX和PULL解析天气预报XML

    PULL解析器同样逐行读取XML,但开发者需要主动调用next方法前进到下一个事件。这种方式易于理解和实现,适合简单的XML结构。在解析天气预报XML时,我们首先需要创建PullParser对象,然后通过nextTag()方法遍历XML,...

    使用Pull解析xml文件

    本篇文章将详细探讨PULL解析器,它是Android平台特有的一种轻量级、事件驱动的XML解析方法。 1. **PULL解析器介绍** PULL解析器是Android SDK中内置的一种解析XML的机制,特别适合于资源有限的移动设备。它通过...

    Android Pull解析Demo

    "Android Pull解析Demo"就是这样一个示例,它展示了如何利用Android系统内置的Pull解析器(PullParser)来解析XML文档,同时结合Java的反射机制,动态地获取类中的变量值。下面我们将深入探讨这两个关键知识点。 **...

    Android Pull解析

    在Android开发中,"Pull解析"通常指的是使用Pull解析器(Pull Parser)进行XML或JSON数据的解析。这是一种基于事件的解析方式,与SAX解析器相似,但更符合Android平台的特点,允许开发者以更低的内存消耗和更高的...

Global site tag (gtag.js) - Google Analytics