使用DOM来解析XML文档

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
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值