import java.io.*;
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;
/**
* @author Robin
*/
public class DomParseTest {
//(1)得到DOM解析器的工厂实例 //得到javax.xml.parsers.DocumentBuilderFactory;类的实例就是我们要的解析器工厂
DocumentBuilderFactory domfac = DocumentBuilderFactory.newInstance();
public DomParseTest() {
try {
//(2)从DOM工厂获得DOM解析器//通过javax.xml.parsers.DocumentBuilderFactory实例的静态方法newDocumentBuilder()得到DOM解析器
DocumentBuilder dombuilder = domfac.newDocumentBuilder();
//(3)把要解析的XML文档转化为输入流,以便DOM解析器解析它
InputStream is = new FileInputStream("c:\\hell.xml");
//(4)解析XML文档的输入流,得到一个Document 由XML文档的输入流得到一个org.w3c.dom.Document对象,以后的处理都是对Document对象进行的
Document doc = dombuilder.parse(is);
//(5)得到XML文档的根节点 在DOM中只有根节点是一个org.w3c.dom.Element对象。
Element root = doc.getDocumentElement();
//(6)得到节点的子节点
NodeList books = root.getChildNodes();
if (books != null) {
for (int i = 0; i < books.getLength(); i++) {
//这是用一个org.w3c.dom.NodeList接口来存放它所有子节点的,还有一种轮循子节点的方法,后面有介绍
Node book = books.item(i);
if (book.getNodeType() == Node.ELEMENT_NODE) {
//(7)取得节点的属性值 注意,节点的属性也是它的子节点。它的节点类型也是Node.ELEMENT_NODE
String email = book.getAttributes().getNamedItem(
"email").getNodeValue();
System.out.println(email);
//(8)轮循子节点
for (Node node = book.getFirstChild(); node != null; node = node
.getNextSibling()) {
if (node.getNodeType() == Node.ELEMENT_NODE) {
if (node.getNodeName().equals("name")) {
// String name=node.getNodeValue(); 是一个空值。而
// String name1=node.getFirstChild().getNodeValue();
//才是真正的值,这是因为DOM把<name> rjzjh</name>也当作是两层结构的节点,
//其父节点为<name>节点本身,且它只有一个子节点(如果有属性的话就不止一个了!),
//子节点是它的值“rjzjh”,所以我们看到上面的结果。
String name = node.getNodeValue();// 是一个空值
String name2 = node.getTextContent();// 是一个空值
String name1 = node.getFirstChild()
.getNodeValue();
System.err.println(name);
System.out.println(name1);
System.out.println(name2);
}
if (node.getNodeName().equals("price")) {
String price = node.getFirstChild()
.getNodeValue();
System.out.println(price);
}
}
}
}
}
}
} catch (ParserConfigurationException e) {
e.printStackTrace();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (SAXException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
public static void main(String[] args) {
new DomParseTest();
}
}
分享到:
相关推荐
Java DOM 解析 XML 实例是 Java 语言中常用的 XML 解析方法之一,使用 W3C 推荐的文档对象模型(Document Object Model,DOM)来解析 XML 文档。DOM 提供了一个树形结构的对象模型,通过遍历树形结构可以访问和操作 ...
在Java平台上,DOM解析器提供了对XML文档的全面和结构化的访问。 使用DOM解析XML的基本步骤如下: 1. **导入必要的库**:在Java中,DOM解析功能主要由`javax.xml.parsers`和`org.w3c.dom`包提供。因此,首先需要在...
以下是一个简单的DOM解析XML文件的步骤: 1. 创建`DocumentBuilderFactory`实例: ```java DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance(); ``` 2. 使用工厂实例创建`DocumentBuilder`...
这些库提供了创建DOM解析器、解析XML文件和操作XML节点的功能。 ### 3. 实现步骤 #### (1) 导入所需的库 ```java import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.parsers.DocumentBuilder; ...
标题中的"DOM_XML.rar"可能是一个包含DOM解析XML相关示例的压缩文件,"DOM_dom xml_dom xml java_dom解析xml_java解析xml"这部分描述了文件的主要内容,即关于DOM(Document Object Model)在XML解析中的应用,特别...
这个库的出现是为了弥补Java标准库中DOM和SAX解析器的不足,提供了更加方便和高效的API。 在DOM4J中生成XML文件主要涉及以下几个关键概念和步骤: 1. **Document对象**:这是DOM4J的核心,表示整个XML文档。你可以...
使用DOM解析XML文件的步骤如下: 1. 加载XML文件:首先,你需要创建一个`DocumentBuilderFactory`对象,然后通过`newDocumentBuilder()`方法得到一个`DocumentBuilder`实例。接着,调用`parse()`方法,传入XML文件...
本文将深入探讨两种主要的XML解析方法——SAX(Simple API for XML)和DOM(Document Object Model),并讲解如何使用它们来解析XML文件以及生成XML文件。 一、SAX解析XML SAX是一种事件驱动的解析器,它逐行扫描...
在Java中,解析XML文件是常见的任务,通常有DOM(Document Object Model)和DOM4J两种方式。下面我们将详细探讨这两种解析方法。 DOM解析方式是将整个XML文件加载到内存中,形成一棵DOM树,每个节点代表XML文档的一...
总的来说,使用Pull解析器读取和生成XML文件是一种高效且灵活的方法,尤其适合处理大型XML文档。通过掌握这一技术,开发者可以更好地处理XML数据,提高程序的性能和稳定性。在进行XML操作时,还需注意数据的正确性和...
使用`DocumentBuilderFactory`创建一个解析器工厂实例,然后通过`newDocumentBuilder()`方法获取DOM解析器。 ```java DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); DocumentBuilder ...
在Java中,解析XML文件是处理这些数据的关键步骤。本篇文章将详细介绍如何使用DOM(Document Object Model)和DOM4j这两种流行的方法来解析XML文件。 首先,DOM是一种标准的W3C推荐的解析XML的方法,它将整个XML...
DOM解析器是XML解析方法之一,它将整个XML文档加载到内存中,形成一个完整的节点树。通过这个树,开发人员可以方便地遍历、查询、修改或操作XML文档的结构。例如,你可以使用DOM API来查找特定元素、获取属性值、...
在这个实例中,我们将深入探讨如何使用DOM4J解析XML文件,并通过`Dom4jTest1.java`这个示例程序来理解其工作原理。 首先,我们需要了解XML(Extensible Markup Language)是一种标记语言,常用于存储和传输数据。...
在压缩包中的`Dom_xml.java`文件很可能包含了以上步骤的实现,展示了如何用DOM解析XML。而`jar`文件可能包含了一些额外的库或工具,如SAX解析器等,它们可能被`Dom_xml.java`引用。在实际开发中,我们需要确保正确地...
本文将深入探讨如何使用SAX、DOM和Pull解析器解析XML文件,以及如何生成XML文件。我们将同时展示Java和Kotlin两种语言的实现方法。 一、SAX解析XML文件 SAX(Simple API for XML)是一种事件驱动的解析器,它不会一...
DOM解析器将整个XML文件加载到内存中,形成一个树形结构,可以方便地遍历和修改XML文档的任何部分。然而,由于它需要一次性加载整个文件,对于大文件来说可能会消耗大量内存。 在"ReadXMLDemo"中,使用DOM解析的...
`DocumentBuilder`代表具体的DOM解析器,它负责解析XML文档并构建DOM树。 3. **解析XML文档** ```java Document doc = db.parse("path/to/xml/file"); ``` 使用`DocumentBuilder`的`parse()`方法读取XML文档,...
DOM解析器将整个XML文档加载到内存中,构建一个树形结构,称为DOM树。每个XML元素、属性、文本等都有对应的DOM节点。这种解析方式的特点是可以方便地通过节点关系进行任意位置的访问和修改,适合对XML文档进行随机...