首先得到:得到
DOM
解析器的工厂实例
DocumentBuilderFactory domfac=DocumentBuilderFactory.newInstance();
然后从
DOM
工厂获得
DOM
解析器
DocumentBuilder dombuilder=domfac.newDocumentBuilder();
3
)把要解析的
XML
文档转化为输入流,以便
DOM
解析器解析它
InputStream is=
new
FileInputStream("test1.xml");
(
4
)解析
XML
文档的输入流,得到一个
Document
Document doc=dombuilder.parse(is);
(
5
)得到
XML
文档的根节点
Element root=doc.getDocumentElement();
(
6
)得到节点的子节点
NodeList books=root.getChildNodes();
package com.st.demo;
import java.io.File;
import java.io.FileInputStream;
import java.io.InputStream;
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;
public class XmlReader {
public static void main(String[] args) {
XmlReader reader = new XmlReader();
}
public XmlReader(){
DocumentBuilderFactory domfac = DocumentBuilderFactory.newInstance();
try {
DocumentBuilder domBuilder = domfac.newDocumentBuilder();
InputStream is = new FileInputStream(new File("D:/test1.xml"));
Document doc = domBuilder.parse(is);
Element root = doc.getDocumentElement();
NodeList books = root.getChildNodes();
if(books!=null){
for (int i = 0; i < books.getLength(); i++) {
Node book = books.item(i);
if(book.getNodeType()==Node.ELEMENT_NODE) {
//(7)取得节点的属性值
String email=book.getAttributes().getNamedItem("email").getNodeValue();
System.out.println(email);
//注意,节点的属性也是它的子节点。它的节点类型也是Node.ELEMENT_NODE
//(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();
System.out.println(name);
System.out.println(name1);
}
if(node.getNodeName().equals("price")) {
String price=node.getFirstChild().getNodeValue();
System.out.println(price);
}
}
}
}
}
}
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
<?xml version="1.0" encoding="GB2312" standalone="no"?>
<books>
<book email="zhoujunhui">
<name>rjzjh</name>
<price>jjjjjj</price>
</book>
</books>
分享到:
相关推荐
使用`FileInputStream`读取XML文件内容,然后调用`DocumentBuilder`的`parse()`方法将输入流解析为`Document`对象,这一步构建了整个XML文档的DOM树。 ```java InputStream is = new FileInputStream("test1.xml")...
本篇文章将详细阐述如何使用Java的`DocumentBuilderFactory`来解析XML文档。 `DocumentBuilderFactory`是Java API中的一个关键类,它是用于创建`DocumentBuilder`对象的工厂。`DocumentBuilder`对象能够解析XML文档...
在IT行业中,调用Web服务并解析XML是常见的任务,特别是在Java开发中。Web服务,尤其是基于SOAP(Simple Object Access Protocol)的,提供了一种标准的跨平台、跨语言的数据交换方式。本教程将深入讲解如何在Java...
总结来说,Java提供了多种解析XML的方法,包括DOM、SAX和JAXB等。对于处理多级嵌套的XML,DOM和JAXB在操作上更为便捷,而SAX则适用于处理大规模文件。在具体选择时,应根据项目需求和资源限制进行权衡。
Java 调用天气接口的知识点总结 ...Java 调用天气接口需要掌握 Java 语言的基础知识,了解 WebService 的调用机制,熟悉 XML 解析和日期时间处理等技术。同时,需要了解天气预报服务的提供和使用。
1. DOM解析:使用`javax.xml.parsers.DocumentBuilderFactory`和`DocumentBuilder`创建一个解析器实例,然后调用`parse()`方法解析XML文件,返回一个`Document`对象。之后,可以通过`Document`对象的`...
### JAVA调用SAP ODATA服务的关键知识点 在IT领域,特别是企业级应用开发中,Java与SAP系统的集成是一项非常重要的技术。SAP提供了多种API和服务来促进与其他系统的交互,其中ODATA(Open Data Protocol)是一种轻...
在Java编程中,调用XML(可扩展标记语言)文件是一项常见的任务,因为XML被广泛用于数据交换、配置存储和结构化数据表示。本篇将详细介绍四种不同的方法,供Java开发者在项目中读取和处理XML文件。 1. **DOM解析器*...
- 解析XML文件:调用`parse()`方法解析XML文件,返回一个`Document`对象。 - 访问XML数据:通过`Document`对象的`getElementsByTagName()`、`getFirstChild()`等方法遍历并获取元素、属性和文本。 2. SAX解析: SAX...
- 读取:首先创建`DocumentBuilderFactory`实例,然后用其创建`DocumentBuilder`,最后调用`parse()`方法解析XML文件。 - 写入:通过`TransformerFactory`和`Transformer`,将DOM树转换为XML输出。 2. 使用SAX...
总之,Java调用SAP ODATA服务涉及的身份验证、请求方法选择、跨域处理以及错误管理是关键步骤,理解并正确处理这些问题能够确保与SAP系统的顺利集成。同时,XML处理能力也是必不可少的,因为ODATA服务通常以XML格式...
下面我们将详细探讨Java调用WebService的相关知识点。 1. **WebService概念**: WebService是一种基于互联网的、平台无关的应用程序接口,它允许不同系统之间通过标准协议进行通信。常见的WebService协议有SOAP...
在Java编程中,生成XML文件并发送报文是一项常见的任务,尤其在系统间的数据交换、API调用或者网络通信中。XML(eXtensible Markup Language)是一种结构化数据表示语言,具有良好的可读性和可扩展性,是数据传输的...
Java语言在处理XML文件时,通常使用两种主要的方法:DOM(Document Object Model)和SAX(Simple API for XML)。在本场景中,我们主要关注DOM方法,因为标题和描述提到了“在内存中构造一个DOM树”。DOM允许我们将...
在Java中,我们可以使用`javax.xml.parsers.DocumentBuilderFactory`和`org.w3c.dom.Document`来解析XML文档,然后遍历DOM树,将其节点转化为Map。例如,每个XML元素的标签名作为键,元素的文本内容作为值。如果元素...
通过调用XmlDocument的write()方法,可以直接将更新后的DOM树写回XML文件。这简化了同步更新的过程,但要注意,这种方法只适用于与Apache Crimson兼容的情况,不具有通用性。 方法三:DOM Level 2的Transformer接口...
首先,我们需要使用Java的`javax.xml.parsers.DocumentBuilderFactory`和`javax.xml.parsers.DocumentBuilder`类来创建一个解析器,用于读取和解析XML文件。以下是一个基本的步骤: 1. 创建`DocumentBuilderFactory...
然后,调用`parse()`方法读取XML文件并将其解析为`Document`对象。 - JAXB解析:如果XML文件与Java对象模型有明确的一对一关系,JAXB提供了一种更便捷的方法。使用`Unmarshaller`可以从XML文件中创建Java对象,而`...
在Java中,我们可以使用`javax.xml.parsers.DocumentBuilderFactory`和`javax.xml.parsers.DocumentBuilder`来创建并解析XML文档。例如: ```java DocumentBuilderFactory factory = DocumentBuilderFactory.new...