XML
2016-07-06 22:33
281 查看
1.Pull简介
Pull解析器是Android系统内置的的,Pull解析器与SAX解析器类似,他提供了类似的事件,如开始元素和介绍元素的事件,使用parser.next()可以进入下一个元素并触发相应的事件,然后进行相应的处理,当元素开始解析时,调用perser.nextText()方法就可以获取到下一个Text类型元素的值。
2.pull特点
一.简单的结构,一个接口,一个另外,一个工厂组成了Pull解析器
二.简单易用,Pull解析器只有一个重要的方法next(),他被用来检索下一个事件,而他的事件也仅仅只有五个,START_DOCUMENT, START_TAG ,TEXT, END_TAG, END_DOCUMENT
三.最小的内存消耗,Pull解析器和SAX解析器一样,对内存的暂用少,但是SAX解析稍微有点繁琐,DOM很耗内存,所以Pull被推荐使用
3,示例 Pull解析XML
先在src目录先新建一个android.xml
新建一个PullXMLService:
DOM解析,DOM比SAX更容易掌握,因为她没有涉及回调和复杂的状态管理,然而,DOM的实现常常将所有的XML节点保存在内存中,这样使的处理较大的文档效率低。
XML基本的节点类型
node - DOM基本的数据类型
Element - 最主要处理的对象是Element
Attr - 元素的属性
Text - 一个Element 或者Attr的实际内容
Document - 代表整个XML文档,一个Document对象通常也称为一颗DOM树
1.在src目录下新建一个android.xml
2.新建一个Person对象来存放解析的内容
3 新建一个DomPersonService.class
关于DOM解析XML,我们要清楚的知道个节点之间的关系,才能更好的操作对象树,值得注意的是在建立Element时,要注意jar包的导入, 要选择org.w3c.dom.Element,而不是其他的包。
Pull解析器是Android系统内置的的,Pull解析器与SAX解析器类似,他提供了类似的事件,如开始元素和介绍元素的事件,使用parser.next()可以进入下一个元素并触发相应的事件,然后进行相应的处理,当元素开始解析时,调用perser.nextText()方法就可以获取到下一个Text类型元素的值。
2.pull特点
一.简单的结构,一个接口,一个另外,一个工厂组成了Pull解析器
二.简单易用,Pull解析器只有一个重要的方法next(),他被用来检索下一个事件,而他的事件也仅仅只有五个,START_DOCUMENT, START_TAG ,TEXT, END_TAG, END_DOCUMENT
三.最小的内存消耗,Pull解析器和SAX解析器一样,对内存的暂用少,但是SAX解析稍微有点繁琐,DOM很耗内存,所以Pull被推荐使用
3,示例 Pull解析XML
先在src目录先新建一个android.xml
<?xml version="1.0" encoding="UTF-8"?> <persons> <person id="23"> <name>xiaanming</name> <age>23</age> </person> <person id="20"> <name>liudehua</name> <age>28</age> </person> </persons>
新建一个PullXMLService:
package com.example.pull_parser; import java.io.InputStream; import java.util.ArrayList; import java.util.List; import org.xmlpull.v1.XmlPullParser; import android.util.Log; import android.util.Xml; public class PullXMLService { public static List<Person> readXML() throws Exception{ //获取src目录下面的android.xml文件的输入流 InputStream is = PullXMLService.class.getClassLoader().getResourceAsStream("android.xml"); //用来存放解析的Person对象 List<Person> persons = null; //一个标记 boolean flag = false; Person person = null; //实例化一个XmlPullParser对象 XmlPullParser parser = Xml.newPullParser(); //设置输入流和编码 parser.setInput(is, "UTF-8"); //触发了第一个事件,根据XML的语法,也就是从他开始了解文档 int eventCode = parser.getEventType(); //如果获得的事件码如果是文档的结束,那么解析结束 while (eventCode != XmlPullParser.END_DOCUMENT) { switch(eventCode){ case XmlPullParser.START_DOCUMENT:{ //开始解析的时候我们一般做一些初始化的操作 persons = new ArrayList<Person>(); break; } case XmlPullParser.START_TAG:{ //判断当前的元素是否是需要检索的元素 if("person".equals(parser.getName())){ flag = true; person = new Person(); person.setId(Integer.valueOf(parser.getAttributeValue(0))); } if(flag){ if("name".equals(parser.getName())){ person.setName(parser.nextText()); }else if("age".equals(parser.getName())){ person.setAge(Integer.valueOf(parser.nextText())); } } ee7b break; } case XmlPullParser.END_TAG:{ if("person".equals(parser.getName()) && person != null){ flag = false; persons.add(person); Log.e("log", person.toString()); person = null; } break; } } //这一步很重要,该方法返回一个事件码,也是触发下一个事件的方法 eventCode = parser.next(); } return persons; } } 好了,这样子就解析完了android.xml
DOM解析,DOM比SAX更容易掌握,因为她没有涉及回调和复杂的状态管理,然而,DOM的实现常常将所有的XML节点保存在内存中,这样使的处理较大的文档效率低。
XML基本的节点类型
node - DOM基本的数据类型
Element - 最主要处理的对象是Element
Attr - 元素的属性
Text - 一个Element 或者Attr的实际内容
Document - 代表整个XML文档,一个Document对象通常也称为一颗DOM树
1.在src目录下新建一个android.xml
<?xml version="1.0" encoding="UTF-8"?> <persons> <person id="23"> <name>xiaanming</name> <age>23</age> </person> <person id="20"> <name>liudehua</name> <age>28</age> </person> </persons>
2.新建一个Person对象来存放解析的内容
package com.example.dom_parser; public class Person { private int id; private String name; private int age; public Person(){} public Person(int id, String name, int age){ this.id = id; this.name = name; this.age = age; } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } @Override public String toString() { return "id = " + id + ", name = " + name + ", age = " + age; } }
3 新建一个DomPersonService.class
package com.example.dom_parser; import java.io.InputStream; import java.util.ArrayList; import java.util.List; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import org.w3c.dom.Document; import org.w3c.dom.Element; import org.w3c.dom.Node; import org.w3c.dom.NodeList; import android.util.Log; public class DomPersonService { public static List<Person> readXML() throws Throwable{ //获得android.xml文件的输入流 InputStream is = MainActivity.class.getClassLoader().getResourceAsStream("android.xml"); List<Person> persons = new ArrayList<Person>(); //实例化DocumentBuilderFactory和DocumentBuilder,并创建Document DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); DocumentBuilder builder = factory.newDocumentBuilder(); Document document = builder.parse(is); //返回文档的根(root)元素 Element rootElement = document.getDocumentElement(); //获取一个Note(DOM基本的数据类型)集合,这里有两个person Note NodeList nodes = rootElement.getElementsByTagName("person"); //遍历Note集合 for(int i=0; i<nodes.getLength(); i++){ //先从第一个person元素开始解析 Element personElement = (Element) nodes.item(i); Person person = new Person(); person.setId(Integer.valueOf(personElement.getAttribute("id"))); //获取person下面的name 和 age 的Note集合 NodeList chileNodes = personElement.getChildNodes(); for(int y=0; y<chileNodes.getLength(); y++){ Node childNode = chileNodes.item(y); //判断子Note的类型为元素Note if(childNode.getNodeType() == Node.ELEMENT_NODE){ Element childElement = (Element) childNode; if("name".equals(childElement.getNodeName())){ person.setName(childElement.getFirstChild().getNodeValue()); }else if("age".equals(childElement.getNodeName())){ person.setAge(Integer.valueOf(childElement.getFirstChild().getNodeValue())); } } } Log.e("log", person.toString()); persons.add(person); } return persons; } }
关于DOM解析XML,我们要清楚的知道个节点之间的关系,才能更好的操作对象树,值得注意的是在建立Element时,要注意jar包的导入, 要选择org.w3c.dom.Element,而不是其他的包。
相关文章推荐
- 修改XenServer无法上传超过4G的ISO(适用于安装XenServer前)
- python虚拟环境
- HDU 2254 - 奥运
- [C#6] 5-自动属性增强
- 堆排序法(c/c++实现)
- 使用Gson解析复杂的json数据
- HDU 4908/BC B BestCoder Sequence
- Fragment
- 9针串口引脚定义 25针串口引脚定义
- unreachable code 报错
- GCC编译过程
- 系统自带功能之相机
- 05_PrintListInReversedOrder从尾到头打印链表
- 映纷视觉小例子
- [SharePoint 2013 入门教程 1 ] 环境搭建
- CSMA/CD和CSMA/CA详解
- NOJ-1080-悄悄话游戏
- POJ 2482(Stars in Your Window-线段树+扫描线)
- 安装npm
- 联想的显示屏校准(困难)