使用DOM来解析XML文档

来源:互联网 发布:电脑黑科技软件 编辑:程序博客网 时间:2024/06/10 12:35

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;

 

 

// 1.生成DOM解析器工厂对象
  DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
  // 2.从解析器工厂得到一个解析器对象
  DocumentBuilder db = dbf.newDocumentBuilder();
  // 3.加载要解析的xml文档
  Document doc = db.parse("student.xml");
  // 4.读取根节点
  Element ele = doc.getDocumentElement();
  System.out.println("根节点的名字是:" + ele.getNodeName());
  // 获取根节点底下所有子节点是个集合
  NodeList list = ele.getChildNodes();
  for (int i = 0; i < list.getLength(); i++) {
   // 判断节点是否为空
   if (list.item(i).getNodeType() == Node.ELEMENT_NODE) {
    Node node = list.item(i);
    System.out.println("节点名:" + node.getNodeName() + ",节点类型:"
      + node.getNodeType());
    NodeList sons = node.getChildNodes();
    System.out.println("每个student节点下有:" + sons.getLength() + "个子节点");
    for (int j = 0; j < sons.getLength(); j++) {
     //判断节点是否为空!
     if (sons.item(j).getNodeType() == Node.ELEMENT_NODE) {
      Node son = sons.item(j);
      System.out.println("son的节点名称:" + son.getNodeName()
        + ",类型:" + son.getNodeType() + ",值:"
        + son.getFirstChild().getNodeValue());
     }
    }
   }

 

 


 // 使用for循环一次查出所有节点内容
   for (Node first = ele.getLastChild(); first != null; first = first
     .getPreviousSibling()) {
    if (first.getNodeType() == Node.ELEMENT_NODE) {
     System.out.println("节点名:" + first.getNodeName() + ",节点类型:"
       + first.getNodeType());
     for (Node son = first.getLastChild(); son != null; son = son
       .getPreviousSibling()) {
      if (son.getNodeType() == Node.ELEMENT_NODE) {
       System.out.println("节点名:" + son.getNodeName()
         + ",节点值:"
         + son.getFirstChild().getNodeValue());
      }
     }
    }
   }

0 0
原创粉丝点击