Android-使用Pull对XML进行增删改查
0. Thanks
Android解析XML的三种方式
Android几种解析XML方式的比较
android xml 解析 修改
android 对xml文件的pull解析,生成xml ,对xml文件的增删
Android中xml 解析三种方式的区别
1.概述
-
PULL是google推荐的解析方式,它和SAX很像,也是从基于流式,从头开始扫描。不过,我们可以控制是否进行下一步扫描,而SAX不行,SAX是一股脑地扫描到文档末尾。而PULL可以在我们扫描到想要的内容后,就直接结束。
-
简单地说就是对文档进行顺序扫描,当扫描到文档(document)开始与结束、元素(element)开始与结束、文档(document)结束等地方时通知事件处理函数,由事件处理函数做相应动作,然后继续同样的扫描,直至文档结束。
-
为了方便说明,先约定好一个XML如下:
<?xml version="1.0" encoding="UTF-8"?>
<persons>
<person id="1" key="33" type="type">
<name>zhangsan</name>
<age>21</age>
</person>
</persons>
2.基本读取(查)
-
基本事件类型:
-
XmlPullParser.START_DOCUMENT:文档开头
-
XmlPullParser.END_DOCUMENT:文档末尾
-
XmlPullParser.START_TAG:标签开始
-
XmlPullParser.END_TAG:标签结束
-
代码如下
File file = new File(xmlFilePath);
try {
InputStream inputStream = new FileInputStream(file);
XmlPullParser parser = Xml.newPullParser();//得到Pull解析器
parser.setInput(inputStream, "UTF-8");//设置下输入流的编码
int eventType = parser.getEventType();//得到第一个事件类型
while (eventType != XmlPullParser.END_DOCUMENT) {//如果事件类型不是文档结束的话则不断处理事件
switch (eventType) {
case (XmlPullParser.START_DOCUMENT)://如果是文档开始事件
Log.i("loadWithPull","START_DOCUMENT");
break;
case (XmlPullParser.START_TAG)://如果遇到标签开始
String tagName = parser.getName();// 获得解析器当前元素的名称
Log.i("loadWithPull","START_TAG:"+tagName);
for (int i = 0; i < parser.getAttributeCount(); i++) {
Log.i("loadWithPull","attr:"+parser.getAttributeName(i)+":"+parser.getAttributeValue(i));
}
if (!parser.isEmptyElementTag()) {
Log.i("loadWithPull","content:"+parser.getText());
}
break;
case (XmlPullParser.END_TAG)://如果遇到标签结束
Log.i("loadWithPull","END_TAG:"+parser.getName());
break;
}
eventType=parser.next();//进入下一个事件处理
}
Log.i("loadWithPull","END_DOCUMENT");
} catch (Exception e) {
e.printStackTrace();
}
- 在扫描到tag的开始,我们便可以读取参数和其内容,如果有内容的话。
- 使用上面的代码,得到的部分log如下:
I/loadWithPull: START_DOCUMENT
I/loadWithPull: START_TAG:persons
I/loadWithPull: content:null
I/loadWithPull: START_TAG:person
I/loadWithPull: attr:id:1
I/loadWithPull: attr:key:33
I/loadWithPull: attr:type:type
I/loadWithPull: content:null
I/loadWithPull: START_TAG:name
I/loadWithPull: content:null
I/loadWithPull: END_TAG:name
I/loadWithPull: START_TAG:age
I/loadWithPull: content:null
I/loadWithPull: END_TAG:age
I/loadWithPull: END_TAG:person
I/loadWithPull: END_TAG:persons
I/loadWithPull: END_DOCUMENT
- 我们发现有些content为null,这是一些换行符,和一些tab。
3.保存,增删
- 和sax的保存,删除,增加一样的做法:Android-使用SAX对XML进行增删改查
4.PULL,SAX,DOM比较
那么他们有什么区别吗?
- 使用SAX解析XML
SAX(Simple API for XML) 使用流式处理的方式,它并不记录所读内容的相关信息。它是一种以事件为驱动的XML API,解析速度快,占用内存少。使用回调函数来实现。 缺点是不能中途结束。
- 使用DOM解析XML
DOM(Document Object Model) 是一种用于XML文档的对象模型,可用于直接访问XML文档的各个部分。它是一次性全部将内容加载在内存中,生成一个树状结构,它没有涉及回调和复杂的状态管理。 缺点是加载大文档时效率低下。
- 使用Pull解析XML
Pull内置于Android系统中。也是官方解析布局文件所使用的方式。Pull与SAX有点类似,都提供了类似的事件,如开始元素和结束元素。不同的是,SAX的事件驱动是回调相应方法,需要提供回调的方法,而后在SAX内部自动调用相应的方法。而Pull解析器并没有强制要求提供触发的方法。因为他触发的事件不是一个方法,而是一个数字。它使用方便,效率高。而且可以提前结束。
DOM | SAX | PULL | |
---|---|---|---|
内存占用 | 大 | 小 | 小 |
解析速度 | 慢 | 快 | 快 |
能否中断 | 否 | 能 | 能 |
随机访问 | 能 | 否 | 否 |
访问修改便利性 | 好 | 差 | 差 |
- 如果只是查找某个字段某个值,推介PULL,如果要频繁修改,可以考虑DOM。当然要看实际情况,没有最优的解,只有最合适的解。