随笔 - 0, 文章 - 75, 评论 - 0, 引用 - 0
数据加载中……

使用DOM解析XML

import java.io.IOException;


import javax.xml.parsers.DocumentBuilder;
import
javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;


import org.w3c.dom.Document;
import org.w3c.dom.Element;
import
org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import
org.xml.sax.SAXException;



public static void main(String[] args) {


//1.得到DOM解析器的工厂实例
DocumentBuilderFactory
dbf = DocumentBuilderFactory.newInstance();
try {


//2.从DOM工厂获得DOM解析器
DocumentBuilder
db = dbf.newDocumentBuilder();


//3.解析XML文档,得到一个Document,即DOM树
Document
doc = db.parse("pet1.xml");


//4.得到所有<狗狗>节点的列表信息
NodeList
list = doc.getElementsByTagName_r("狗狗");


//5.循环狗狗信息
for(int i = 0 ; i
< list.getLength(); i++){


//5.1获取第i个狗狗元素的信息
Element
dog = (Element)list.item(i);


//5.2获取第i个狗狗元素的id属性的值并输出
String
id =
dog.getAttribute("id"); //获得标签里的属性id的值
System.out.println("id:"+id);
//5.3获取第i个狗狗元素的所有子元素的名称和值并输出
for(Node
node = dog.getFirstChild(); node!=null;
node=node.getNextSibling()){
if(node.getNodeType()
==
Node.ELEMENT_NODE){ //判断是否是元素节点
String
name = node.getNodeName();
//根据节点的类型返回节点的名称
String value =
node.getTextContent();
//得到节点里的值(一组值)
System.out.println(name +
" "
+value);
}
}
}

}
catch (ParserConfigurationException e)
{
e.printStackTrace();
} catch (SAXException
e) {
e.printStackTrace();
} catch
(IOException e)
{
e.printStackTrace();
}

}

posted on 2012-04-22 15:32 hantai 阅读(78) 评论(0)  编辑  收藏


只有注册用户登录后才能发表评论。


网站导航:
博客园   IT新闻   Chat2DB   C++博客   博问