Android应用中使用DOM方式解析XML格式数据的基本方法

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,而不是其他的包。

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稍微了解下就可以了。

声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:notice#cainiaojc.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。