Android开发8——利用pull解析器读写XML文件

 

一、基本介绍

对XML解析有SAX和DOM等多种方式,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 END_DOCUMENT ;
读取到xml的开始标签返回数字2 START_TAG
读取到xml的结束标签返回数字3 END_TAG
读取到xml的文本返回数字4 TEXT

<?xml version="1.0" encoding="UTF-8"?>
<people>
	<person id="001">
		<name>XY1</name>
		<age>22</age>
	</person>
	<person id="002">
		<name>XY2</name>
		<age>22</age>
	</person>
</people>

 

package cn.xy.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.XmlSerializer;

import android.util.Xml;
import cn.xy.model.Person;

/**
 * 利用pull解析器解析XML
 *
 * @author XY
 *
 */
public class PersonService
{
	/**
	 * 从XML文件中读取数据
	 *
	 * @param xml XML文件输入流
	 */
	public List<Person> getPeople(InputStream xml) throws Exception
	{
		List<Person> lst = null;
		Person person = null;

		// 利用ANDROID提供的API快速获得pull解析器
		XmlPullParser pullParser = Xml.newPullParser();

		// 设置需要解析的XML数据
		pullParser.setInput(xml, "UTF-8");

		// 取得事件
		int event = pullParser.getEventType();

		// 若为解析到末尾
		while (event != XmlPullParser.END_DOCUMENT) // 文档结束
		{
			String nodeName = pullParser.getName();
			switch (event)
			{
				case XmlPullParser.START_DOCUMENT: // 文档开始
					lst = new ArrayList<Person>();
					break;
				case XmlPullParser.START_TAG: // 标签开始
					if ("person".equals(nodeName))
					{
						String id = pullParser.getAttributeValue(0);
						person = new Person();
						person.setId(id);
					}
					if ("name".equals(nodeName))
					{
						String name = pullParser.nextText();
						person.setName(name);
					}
					if ("age".equals(nodeName))
					{
						int age = Integer.valueOf(pullParser.nextText());
						person.setAge(age);
					}
					break;
				case XmlPullParser.END_TAG: // 标签结束
					if ("person".equals(nodeName))
					{
						lst.add(person);
						person = null;
					}
					break;
			}
			event = pullParser.next(); // 下一个标签
		}
		return lst;
	}

	/**
	 * 向XML写入数据
	 *
	 * @param os
	 * @param person
	 * @throws Exception
	 */
	public void saveDataToXML(OutputStream os, List<Person> lst) throws Exception
	{
		XmlSerializer xs = Xml.newSerializer();
		xs.setOutput(os, "UTF-8");
		xs.startDocument("UTF-8", true);
		xs.startTag(null, "people");
		for (Person p : lst)
		{
			xs.startTag(null, "person");
			xs.attribute(null, "person", p.getId());

			xs.startTag(null, "name");
			xs.text(p.getName());
			xs.endTag(null, "name");

			xs.startTag(null, "age");
			xs.text(p.getAge().toString());
			xs.endTag(null, "age");

			xs.endTag(null, "person");
		}
		xs.endTag(null, "people");
		xs.endDocument();
		os.flush();
		os.close();
	}
}
public class TestClass extends AndroidTestCase
{
	public void testPeople() throws Exception
	{
		PersonService ps = new PersonService();
		InputStream xml = this.getClass().getClassLoader().getResourceAsStream("person.xml");
		List<Person> lst = ps.getPeople(xml);
		Assert.assertEquals("XY1", lst.get(0).getName());
	}

	public void testSave() throws Exception
	{
		PersonService ps = new PersonService();
		List<Person> lst = new ArrayList<Person>();
		lst.add(new Person("0001", "XY0001", 20));
		lst.add(new Person("0002", "XY0002", 20));
		File xmlFile = new File(this.getContext().getFilesDir(), "xy.xml"); // data/data/package name/files
		OutputStream os = new FileOutputStream(xmlFile);
		ps.saveDataToXML(os, lst);
	}
}

 

时间: 2024-10-31 05:01:34

Android开发8——利用pull解析器读写XML文件的相关文章

Android开发之使用Pull解析器生成XML文件

有些时候,我们需要生成一个XML文件,生成XML文件的方法有很多,如:可以只使用一个StringBuilder组拼XML内容,然后把内容写入到文件中:或者使用DOM API生成XML文件,或者也可以使用pull解析器生成XML文件,这里推荐大家使用Pull解析器. 相关代码如下: public static String writeXML(List<Person> persons, Writer writer){     XmlSerializer serializer = Xml.newSe

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

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

java中采用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

Android开发之使用pull解析XML文件

Android已经集成进了Pull解析器,所以无需添加任何jar文件.android系统本身使用到的各种xml文件,其内部也是采用Pull解析器进行解析的. Pull解析器的运行方式与 SAX 解析器相似.它提供了类似的事件,如:开始元素和结束元素事件,使用parser.next()可以进入下一个元素并触发相应事件.跟SAX不同的是, Pull解析器产生的事件是一个数字,而非方法,因此可以使用一个switch对感兴趣的事件进行处理.当元素开始解析时,调用parser.nextText()方法可以

Android开发之利用jsoup解析HTML页面的方法

本文实例讲述了Android利用jsoup解析HTML页面的方法.分享给大家供大家参考,具体如下: 这节主要是讲解jsoup解析HTML页面.由于在android开发过程中,不可避免的涉及到web页面的抓取,解析,展示等等,所以,在这里我主要展示下利用jsoup jar包来抓取cnbeta.com网站的话题分类的实例. 下面是主要的代码,由于使用及其简单,我这里就不再多说了: package com.android.web; import java.io.BufferedInputStream;

android开发基础教程—三种方式实现xml文件解析_Android

1.sax方式 复制代码 代码如下: /** * 使用sax解析 */ public class SaxParse{ /** * sax解析器 */ private SAXParser parser; public SaxParse(){ try { SAXParserFactory f = SAXParserFactory.newInstance(); parser = f.newSAXParser(); } catch (ParserConfigurationException e) { e

android开发基础教程—三种方式实现xml文件解析

1.sax方式 复制代码 代码如下: /** * 使用sax解析 */ public class SaxParse{ /** * sax解析器 */ private SAXParser parser; public SaxParse(){ try { SAXParserFactory f = SAXParserFactory.newInstance(); parser = f.newSAXParser(); } catch (ParserConfigurationException e) { e

wince 利用MSXML 3.0 读写xml文件

Simple XML Parsing on WinCE 4.2 Using C++ and MSXML 3.0 This article will show you how to parse XML files on WinCE using MSXML 3.0, a XML parser from Microsoft. Okay, there are many articles around showing you how to parse XML, but not that many for

Android开发之利用Intent实现数据传递的方法_Android

本文实例讲述了Android利用Intent实现数据传递的方法.分享给大家供大家参考,具体如下: 在Android开发过程中,很多人都熟悉Intent,这是个用于在多个View之间共享数据的类.本节主要讲述通过点选ListView中的文本,把文本中的URL加载到一个新的页面上,并且打印出来.为了方便,我先把前面一篇<Android开发之利用jsoup解析HTML页面的方法>的代码重新贴一下,因为在上一节后,代码做了少许修改: try { doc = Jsoup.parse(new URL(&q