时间:2021-05-19
DOM比SAX更容易掌握,因为她没有涉及回调和复杂的状态管理,然而,DOM的实现常常将所有的XML节点保存在内存中,这样使的处理较大的文档效率低。
XML基本的节点类型
node - DOM基本的数据类型
Element - 最主要处理的对象是Element
Attr - 元素的属性
Text - 一个Element 或者Attr的实际内容
Document - 代表整个XML文档,一个Document对象通常也称为一颗DOM树
1.在src目录下新建一个android.xml
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,而不是其他的包。
PS:DOM解析虽然我们在android中并不推荐使用,但是这并不代表着不可以实现。dom的原理是把xml文件的各种部分都看成是节点,所有的节点因为层级关系最后形成了一颗节点树。而DOM的解析方式便是在内存中生存这棵树,并允许用户进行相关的操作。
这里列出几个dom中经常用到的方法:
Node 接口的常用方法
一个节点可以调用
short getNodeType()
方法返回一个表示节点类型的常量(Node接口规定的常量值),例如,对于Element节点,getNodeType()方法返回的值为:
Node.ELEMENT_NODE
节点可以调用
NodeList getChildNodes()
返回一个由当前节点的所有子节点组成的NodeList对象。节点调用
Node getFirstChild()
返回当前节点的第一个子节点。节点调用
Node getLastChild()
返回当前节点的最后一个子节点。节点可以调用
NodeList getTextContent()
返回当前节点及所有子孙节点中的文本内容。
还有其他的很多很多方法,我们可以通过api来详细了解。因为这里主要是为了学习android,所以关于dom稍微了解下就可以了。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文使用SAX来解析XML,在Android里面可以使用SAX和DOM,DOM需要把整个XML文件读入内存再解析,比较消耗内存,而SAX基于事件驱动的处理方式,
本文实例讲述了Android编程使用pull方式解析xml格式文件的方法。分享给大家供大家参考,具体如下:上次已经说过使用Androidsax解析xml,实际上
1XML文件解析的4种方法通常解析XML文件有四种经典的方法。基本的解析方式有两种,一种叫SAX,另一种叫DOM。SAX是基于事件流的解析,DOM是基于XML文
在android开发中,经常用到去解析xml文件,常见的解析xml的方式有一下三种:SAX、Pull、Dom解析方式。最近做了一个android版的CSDN阅读
一、使用Pull解析器读取XML文件除了可以使用SAX或DOM解析XML文件之外,大家也可以使用Android内置的Pull解析器解析XML文件。Pull解析器