当前位置:编程学习 > XML/UML >>

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 ,
CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,