Android开发(8)--Android中DOM解析xml文件
一、在assets文件中写xml文件
[html]
<?xmlversion="1.0"encoding="UTF-8"?>
<persons>
<personid="23">
<name>李明</name>
<age>30</age>
</person>
<personid="20">
<name>李向梅</name>
<age>25</age>
</person>
</persons>
[html]
<?xml version="1.0" encoding="UTF-8"?>
<persons>
<person id="23">
<name>李明</name>
<age>30</age>
</person>
<person id="20">
<name>李向梅</name>
<age>25</age>
</person>
</persons>
<?xml version="1.0" encoding="UTF-8"?>
<persons>
<person id="23">
<name>李明</name>
<age>30</age>
</person>
<person id="20">
<name>李向梅</name>
<age>25</age>
</person>
</persons>
二、在service中写一个DOM解析的操作
[java]
package com.example.service;
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 com.example.domain.Person;
public class XMLDomService {
public List<Person> parseXML(InputStream is) {
List<Person> list = new ArrayList<Person>();
// 创建DOM工厂对象
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
try {
// DocumentBuilder对象
DocumentBuilder builder = factory.newDocumentBuilder();
// 获取文档对象
Document document = builder.parse(is);
// 获取文档对象的root
Element root = document.getDocumentElement();
// 获取persons根节点中所有的person节点对象
NodeList personNodes = root.getElementsByTagName("person");
// 遍历所有的person节点
for (int i =0; i < personNodes.getLength(); i++) {
Person person = new Person();
// 根据item(index)获取该索引对应的节点对象
Element personNode = (Element) personNodes.item(i); // 具体的person节点
// 设置id属性值
person.setId(Integer.parseInt(personNode.getAttribute("id")));
// 获取该节点下面的所有字节点
NodeList personChildNodes = personNode.getChildNodes();
// 遍历person的字节点
for (int index =0; index < personChildNodes.getLength(); index++) {
// 获取子节点
Node node = personChildNodes.item(index);
// 判断node节点是否是元素节点
if (node.getNodeType() == Node.ELEMENT_NODE) {
//把节点转换成元素节点
Element element = (Element) node;
//判断元素节点是否是name元素节点
if ("name".equals(element.getNodeName())) {
person.setName(element.getFirstChild()
.getNodeValue());
} else if ("age".equals(element.getNodeName())) {//判断是否是age节点
person.setAge(new Short(element.getFirstChild()
.getNodeValue()));
}
}
}
// 把person对象加入到集合中
list.add(person);
}
//关闭输入流
is.close();
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return list;
}
}
[java]
package com.example.service;
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 com.example.domain.Person;
public class XMLDomService {
public List<Person> parseXML(InputStream is) {
List<Person> list = new ArrayList<Person>();
// 创建DOM工厂对象
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
try {
// DocumentBuilder对象
DocumentBuilder builder = factory.newDocumentBuilder();
// 获取文档对象
Document document = builder.parse(is);
// 获取文档对象的root
Element root = document.getDocumentElement();
// 获取persons根节点中所有的person节点对象
NodeList personNodes = root.getElementsByTagName("person");
// 遍历所有的person节点
for (int i = 0; i < personNodes.getLength(); i++) {
Person person = new Person();
// 根据item(index)获取该索引对应的节点对象
Element personNode = (Element) personNodes.item(i); // 具体的person节点
// 设置id属性值
person.setId(Integer.parseInt(personNode.getAttribute("id")));
// 获取该节点下面的所有字节点
NodeList personChildNodes = personNode.getChildNodes();
// 遍历person的字节点
for (int index = 0; index < personChildNodes.getLength(); index++) {
 
补充:移动开发 , Android ,