JAVA 用DOM解析XML

Java 中的 DOM 接口简介: JDK 中的 DOM API 遵循 W3C DOM 规范,其中 org.w3c.dom 包提供了 Document、DocumentType、Node、NodeList、Element 等接口, 这些接口均是访问 DOM 文档所必须的。我们可以利用这些接口创建、遍历、修改 DOM 文档。

javax.xml.parsers 包中的 DoumentBuilder 和 DocumentBuilderFactory 用于解析 XML 文档生成对应的 DOM Document 对象。

javax.xml.transform.dom 和 javax.xml.transform.stream 包中 DOMSource 类和 StreamSource 类,用于将更新后的 DOM 文档写入 XML 文件。

下面给出一个运用 DOM 解析 XML 的例子:

 
 
  1. import java.io.File;   
  2.  import java.io.IOException;   
  3.  import javax.xml.parsers.DocumentBuilder;   
  4.  import javax.xml.parsers.DocumentBuilderFactory;   
  5.  import javax.xml.parsers.ParserConfigurationException;   
  6.  import org.w3c.dom.Document;   
  7.  import org.w3c.dom.Element;   
  8.  import org.w3c.dom.Node;   
  9.  import org.w3c.dom.NodeList;   
  10.  import org.xml.sax.SAXException;   
  11.  
  12.  public class DOMParser {   
  13.    DocumentBuilderFactory builderFactory = DocumentBuilderFactory.newInstance();   
  14.    //Load and parse XML file into DOM   
  15.    public Document parse(String filePath) {   
  16.       Document document = null;   
  17.       try {   
  18.          //DOM parser instance   
  19.          DocumentBuilder builder = builderFactory.newDocumentBuilder();   
  20.          //parse an XML file into a DOM tree   
  21.          document = builder.parse(new File(filePath));   
  22.       } catch (ParserConfigurationException e) {   
  23.          e.printStackTrace();    
  24.       } catch (SAXException e) {   
  25.          e.printStackTrace();   
  26.       } catch (IOException e) {   
  27.          e.printStackTrace();   
  28.       }   
  29.       return document;   
  30.    }   
  31.       
  32.    public static void main(String[] args) {   
  33.          DOMParser parser = new DOMParser();   
  34.          Document document = parser.parse("books.xml");   
  35.          //get root element   
  36.          Element rootElement = document.getDocumentElement();   
  37.  
  38.          //traverse child elements   
  39.          NodeList nodes = rootElement.getChildNodes();   
  40.          for (int i=0; i < nodes.getLength(); i++)   
  41.          {   
  42.             Node node = nodes.item(i);   
  43.             if (node.getNodeType() == Node.ELEMENT_NODE) {     
  44.                Element child = (Element) node;   
  45.                //process child element   
  46.             }   
  47.          }   
  48.  
  49.          NodeList nodeList = rootElement.getElementsByTagName("book");   
  50.          if(nodeList != null)   
  51.          {   
  52.             for (int i = 0 ; i < nodeList.getLength(); i++)   
  53.             {   
  54.                Element element = (Element)nodeList.item(i);   
  55.                String id = element.getAttribute("id");   
  56.             }   
  57.          }   
  58.    }   
  59.  }  

在上面的例子中,DOMParser 的 Parse() 方法负责解析 XML 文件并生成对应的 DOM Document 对象。其中 DocumentBuilderFactory 用于生成 DOM 文档解析器以便解析 XML 文档。 在获取了 XML 文件对应的 Document 对象之后,我们可以调用一系列的 API 方便的对文档对象模型中的元素进行访问和处理。 需要注意的是调用 Element 对象的 getChildNodes() 方法时将返回其下所有的子节点,其中包括空白节点,因此需要在处理子 Element 之前对节点类型加以判断。

可以看出 DOM 解析 XML 易于开发,只需要通过解析器建立起 XML 对应的 DOM 树型结构后便可以方便的使用 API 对节点进行访问和处理,支持节点的删除和修改等。 但是 DOM 解析 XML 文件时会将整个 XML 文件的内容解析成树型结构存放在内存中,因此不适合用 DOM 解析很大的 XML 文件。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值