首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > XML SOAP >

应用DOM解析XML

2012-12-26 
使用DOM解析XML?import java.io.IOExceptionimport javax.xml.parsers.DocumentBuilderimport javax.xml

使用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();
??}
????
?}

热点排行