昨天晚上发了一篇用SAX解析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,而不是其他的包,好了,今天就到这里,洗澡睡觉去,明天还要上班