您的位置:首页 > 编程语言 > Java开发

JAVA 用DOM解析XML

2015-09-13 14:36 453 查看
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 的例子:
import java.io.File;   
 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 class DOMParser {   
   DocumentBuilderFactory builderFactory = DocumentBuilderFactory.newInstance();   
   //Load and parse XML file into DOM   
   public Document parse(String filePath) {   
      Document document = null;   
      try {   
         //DOM parser instance   
         DocumentBuilder builder = builderFactory.newDocumentBuilder();   
         //parse an XML file into a DOM tree   
         document = builder.parse(new File(filePath));   
      } catch (ParserConfigurationException e) {   
         e.printStackTrace();    
      } catch (SAXException e) {   
         e.printStackTrace();   
      } catch (IOException e) {   
         e.printStackTrace();   
      }   
      return document;   
   }   
      
   public static void main(String[] args) {   
         DOMParser parser = new DOMParser();   
         Document document = parser.parse("books.xml");   
         //get root element   
         Element rootElement = document.getDocumentElement();   
 
         //traverse child elements   
         NodeList nodes = rootElement.getChildNodes();   
         for (int i=0; i < nodes.getLength(); i++)   
         {   
            Node node = nodes.item(i);   
            if (node.getNodeType() == Node.ELEMENT_NODE) {     
               Element child = (Element) node;   
               //process child element   
            }   
         }   
 
         NodeList nodeList = rootElement.getElementsByTagName("book");   
         if(nodeList != null)   
         {   
            for (int i = 0 ; i < nodeList.getLength(); i++)   
            {   
               Element element = (Element)nodeList.item(i);   
               String id = element.getAttribute("id");   
            }   
         }   
   }   
 }  

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

可以看出 DOM 解析 XML 易于开发,只需要通过解析器建立起 XML 对应的 DOM 树型结构后便可以方便的使用 API 对节点进行访问和处理,支持节点的删除和修改等。 但是 DOM 解析 XML 文件时会将整个 XML 文件的内容解析成树型结构存放在内存中,因此不适合用 DOM 解析很大的 XML 文件。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: