博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
android数据存储与访问之使用pull解析器
阅读量:4175 次
发布时间:2019-05-26

本文共 3246 字,大约阅读时间需要 10 分钟。

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

如下为要解析的XML文件

文件名称:persons.xml
allen
36
james
25
例子定义了一个javabean用于存放上面解析出来的xml内容, 这个javabean为Person,如下:
public class Person {	private Integer id;	private String name;	private Short age;		public Integer getId() {		return id;	}	public void setId(Integer id) {		this.id = id;	}	public String getName() {		return name;	}	public void setName(String name) {		this.name = name;	}	public Short getAge() {		return age;	}	public void setAge(Short age) {		this.age = age;	}	}

使用Pull解析器读取itcast.xml的代码如下:

import org.xmlpull.v1.XmlPullParser;import android.util.Xml;import cn.itcast.xml.domain.Person;public class PullXMLReader {public static List
readXML(InputStream inStream) { XmlPullParser parser = Xml.newPullParser(); try { parser.setInput(inStream, "UTF-8"); int eventType = parser.getEventType(); Person currentPerson = null; List
persons = null; while (eventType != XmlPullParser.END_DOCUMENT) { switch (eventType) { case XmlPullParser.START_DOCUMENT://文档开始事件,可以进行数据初始化处理 persons = new ArrayList
(); break; case XmlPullParser.START_TAG://开始元素事件 String name = parser.getName(); if (name.equalsIgnoreCase("person")) { currentPerson = new Person(); currentPerson.setId(new Integer(parser.getAttributeValue(null, "id"))); } else if (currentPerson != null) { if (name.equalsIgnoreCase("name")) { currentPerson.setName(parser.nextText());// 如果后面是Text节点,即返回它的值 } else if (name.equalsIgnoreCase("age")) { currentPerson.setAge(new Short(parser.nextText())); } } break; case XmlPullParser.END_TAG://结束元素事件 if (parser.getName().equalsIgnoreCase("person") && currentPerson != null) { persons.add(currentPerson); currentPerson = null; } break; } eventType = parser.next(); } inStream.close(); return persons; } catch (Exception e) { e.printStackTrace(); } return null;}}
使用Pull解析器生成XML文件

有些时候,我们需要生成一个XML文件,生成XML文件的方法有很多,如:可以只使用一个StringBuilder组拼XML内容,然后把内容写入到文件中;或者使用DOM API生成XML文件,或者也可以使用pull解析器生成XML文件,这里推荐大家使用Pull解析器。
使用Pull解析器生成一个与persons.xml
使用代码如下(生成XML文件):
File xmlFile = new File("persons.xml");
FileOutputStream outStream = new FileOutputStream(xmlFile);
OutputStreamWriter outStreamWriter = new OutputStreamWriter(outStream, "UTF-8");
BufferedWriter writer = new BufferedWriter(outStreamWriter);
writeXML(persons, writer);
writer.flush();
writer.close();
如果只想得到生成的xml字符串内容,可以使用StringWriter:
StringWriter writer = new StringWriter();
writeXML(persons, writer);
String content = writer.toString();

转载地址:http://nhtai.baihongyu.com/

你可能感兴趣的文章
How Hash Algorithms Work
查看>>
power consumption/capacity unit 耗电 /电池容量
查看>>
display work need to do at initial stage in a project
查看>>
Linux中的DRM
查看>>
debug
查看>>
driver 和 hardware 到底什么关系
查看>>
io port / io memory
查看>>
MODULE_DEVICE_TABLE
查看>>
firmware的加载,更新一些基本概念
查看>>
DRI &DRM
查看>>
display 中的 overlay 的文章搜集
查看>>
Kconfig
查看>>
git
查看>>
repo
查看>>
git patch
查看>>
git rebase
查看>>
git-am合并git format-patch
查看>>
git reset
查看>>
修改git commit 除了 git commit --amend 还有 git commmit rebase, reset,
查看>>
grep 常用用法
查看>>