[Java开发之路](12)JDOM和DOM4J解析XML文档

1. JDOM解析XML文档

1.1 简介

JDOM是一个开源项目,它基于树型结构,利用纯JAVA的技术对XML文档实现解析、生成、序列化以及多种操作。 JDOM 直接为JAVA编程服务。它利用更为强有力的JAVA语言的诸多特性(方法重载、集合概念以及映射),把SAX和DOM的功能有效地结合起来。 在使用设计上尽可能地隐藏原来使用XML过程中的复杂性。利用JDOM处理XML文档将是一件轻松、简单的事。

JDOM帮助文档 :  http://www.jdom.org/docs/apidocs/

Jar包下载地址: 点击打开链接

1.2 解析步骤

(1)创建SAXBuilder对象
   
   
SAXBuilder saxBuilder = new SAXBuilder();
(2)创建输入流对象并将XML文档加载到输入流中
   
   
FileInputStream inputStream = new FileInputStream("D:\\bookstore.xml");
(3)通过saxBuilder对象的build方法将输入流加载到saxBuilder中(注意:Document 所引用的包是org.jdom2.Document;)
   
   
Document document = saxBuilder.build(inputStream);
(4)通过document对象获取XML文档的根节点
   
   
Element rootElement = document.getRootElement();
(5)根据根节点获取根节点下的子节点集合
   
   
List<Element> bookList = rootElement.getChildren();
(6)根据节点获取属性节点集合
   
   
List<Attribute> attrList = book.getAttributes();
(7)根据节点(元素节点或者属性节点)获取节点名称和节点值
   
   
// 属性名称
node.getName();
// 属性值
node.getValue();
1.3 主要方法

(1) 返回文档的根节点
public Element getRootElement()
  
  
// document为Document对象
Element rootElement = document.getRootElement();
(2) 返回节点的所有子节点的集合
public java.util.List<Element> getChildren()
  
  
// rootElement为Element对象
List<Element> bookList = rootElement.getChildren();
(3) 返回节点的所有属性节点的集合
public java.util.List<Attribute> getAttributes()
   
   
// book为Element对象
List<Attribute> attrList = book.getAttributes()
(4)根据子节点的名称返回节点的子节点
public Element getChild(java.lang.String cname)
   
   
Element titleElement = book.getChild("title");
(5)返回节点的名称
public java.lang.String getName()
   
   
// titleElement为title节点
titleElement.getName();
(6)返回节点值
public java.lang.String getValue()、
   
   
titleElement.getValue()
DOM方式getNodeValue() 对于元素节点时返回null。不同于DOM方式,JDOM无论是属性节点还是元素节点都会返回节点对应的文本值。
   
   
<author>Scott Meyers</author>
对于这个节点来说,DOM的getNodeValue()返回null,JDOM的getValue()返回"Scott Meyers"。

1.3 具体实例

   
   
package com.qunar.xml;
 
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.util.List;
 
import org.jdom2.Attribute;
import org.jdom2.Document;
import org.jdom2.Element;
import org.jdom2.JDOMException;
import org.jdom2.input.SAXBuilder;
 
/**
* JDOM解析XML文档
* @author sjf0115
*
*/
public class JDOMXMLCode {
 
public static void main(String[] args) {
try {
// 创建SAXBuilder对象
SAXBuilder saxBuilder = new SAXBuilder();
// 创建输入流对象并将XML文档加载到输入流中
FileInputStream inputStream = new FileInputStream("D:\\bookstore.xml");
// 通过saxBuilder对象的build方法将输入流加载到saxBuilder中
Document document = saxBuilder.build(inputStream);
// 通过document对象获取XML文档的根节点
Element rootElement = document.getRootElement();
// 根据根节点获取根节点下的子节点集合
List<Element> bookList = rootElement.getChildren();
// 遍历子节点
for (Element book : bookList) {
System.out.println("开始解析一本书...");
// 解析属性
List<Attribute> attrList = book.getAttributes();
for (Attribute attribute : attrList) {
// 属性名称
System.out.print("---" + attribute.getName() + ":");
// 属性值
System.out.println(attribute.getValue());
}//for
// 获取book节点下的子节点
List<Element> bookChildren = book.getChildren();
for (Element bookChild : bookChildren) {
// 节点名称
System.out.print("------" + bookChild.getName() + ":");
// 节点值
System.out.println(bookChild.getValue());
}//for
System.out.println("结束解析一本书...");
}//for
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (JDOMException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
}


运行结果:

开始解析一本书...
---category:Java
------title:Java多线程编程核心技术
------author:高洪岩
------year:2015
------price:69.00
结束解析一本书...
开始解析一本书...
---category:C++
------title:Effective C++: 55 Specific Ways to Improve Your Programs and Designs
------author:Scott Meyers
------year:2006
------price:58.00
结束解析一本书...
开始解析一本书...
---category:Web
------title:Learning XML
------author:Erik T. Ray
------year:2016
------price:39.95
结束解析一本书...


2. DOM4J解析XML文档

2.1 简介

DOM4J是一个Java的XML API,类似于JDOM,用来读写XML文件的。 DOM4J 是一个十分优秀的JavaXML API,具有性能优异、功能强大和极其易使用的特点,同时它也是一个开放源代码的软件,可以在SourceForge上找到它。如今可以看到越来越多的Java软件都在使用 DOM4J 来读写XML,特别值得一提的是连Sun的JAXM也在用 DOM4J 。这已经是必须使用的jar包, Hibernate也用它来读写配置文件。

Jar包下载地址:点击打开链接

2.2解析

(1)创建SAXReader对象
   
   
SAXReader saxReader = new SAXReader();
(2)通过SaxReader对象的read方法加载XML文档获取Document对象
   
   
Document document = saxReader.read(new File("D:\\bookstore.xml"));
(3)通过Document对象获取根节点
   
   
Element bookstore = document.getRootElement();
(4)通过Element对象的elementIterator方法获取迭代器
   
   
Iterator iterator = bookstore.elementIterator();
(5)遍历迭代器获取根节点的信息
   
   
while (iterator.hasNext()) {
// 获取下一个子节点
Element book = (Element)iterator.next();
}
(6)获取属性节点的属性名称和属性值
   
   
// 获取book的属性节点集合
List<Attribute> bookAttr = book.attributes();
// 遍历book属性节点
for (Attribute attribute : bookAttr) {
// 获取book的属性节点的属性名称以及属性值
System.out.println("name:" + attribute.getName() + " value:" + attribute.getValue());
}//for
(7)获取元素节点的节点名称和对应的文本值
  
  
Iterator ite = book.elementIterator();
// 遍历book节点的子节点
while(ite.hasNext()){
// book节点的子节点
Element bookChild = (Element)ite.next();
System.out.println("name:" + bookChild.getName() + " value:" + bookChild.getStringValue());
//System.out.println("name:" + bookChild.getName() + " value:" + bookChild.getText());
}//while

2.3 具体案例

   
   
package com.qunar.xml;
 
import java.io.File;
import java.util.Iterator;
import java.util.List;
 
import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
 
public class DOM4JXMLCode {
 
public static void main(String[] args) {
try {
// 创建SAXReader对象
SAXReader saxReader = new SAXReader();
// 通过SaxReader对象的read方法加载XML文档获取Document对象
Document document = saxReader.read(new File("D:\\bookstore.xml"));
// 通过Document对象获取根节点
Element bookstore = document.getRootElement();
// 通过Element对象的elementIterator方法获取迭代器
Iterator iterator = bookstore.elementIterator();
// 遍历根节点的子节点
while (iterator.hasNext()) {
System.out.println("开始解析一本书...");
// 获取下一个元素节点
Element book = (Element)iterator.next();
// 获取book的属性节点集合
List<Attribute> bookAttr = book.attributes();
// 遍历book属性节点
for (Attribute attribute : bookAttr) {
// 获取book的属性节点的属性名称以及属性值
System.out.println("name:" + attribute.getName() + " value:" + attribute.getValue());
}//for
Iterator ite = book.elementIterator();
// 遍历book节点的子节点
while(ite.hasNext()){
// book节点的子节点
Element bookChild = (Element)ite.next();
System.out.println("name:" + bookChild.getName() + " value:" + bookChild.getStringValue());
//System.out.println("name:" + bookChild.getName() + " value:" + bookChild.getText());
}//while
System.out.println("结束解析一本书...");
}
} catch (DocumentException e) {
e.printStackTrace();
}
}
}
运行结果:

开始解析一本书...
name:category   value:Java
name:title   value:Java多线程编程核心技术
name:author   value:高洪岩
name:year   value:2015
name:price   value:69.00
结束解析一本书...
开始解析一本书...
name:category   value:C++
name:title   value:Effective C++: 55 Specific Ways to Improve Your Programs and Designs
name:author   value:Scott Meyers
name:year   value:2006
name:price   value:58.00
结束解析一本书...
开始解析一本书...
name:category   value:Web
name:title   value:Learning XML
name:author   value:Erik T. Ray
name:year   value:2016
name:price   value:39.95
结束解析一本书...







  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 好的,我可以回答你关于Java解析XML代码的问题。 在Java中,可以使用多种方法来解析XML文档。以下是一些常用的方法: 1. 使用Java内置的DOM解析器:DOM(文档对象模型)是一种基于树结构的解析器,它将整个XML文档解析为一棵树,可以方便地对节点进行操作。 2. 使用Java内置的SAX解析器:SAX(简单API for XML)是一种基于事件驱动的解析器,它逐行读取XML文档并触发事件,可以在读取XML文档时进行处理。 3. 使用第三方库,如JDOM、DOM4J等:这些库提供了更方便的API来解析XML文档。 下面是一个使用DOM解析解析XML文档的示例代码: ```java import javax.xml.parsers.*; import org.w3c.dom.*; public class DomParserExample { public static void main(String[] args) { try { // 创建解析器工厂 DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); // 创建解析DocumentBuilder builder = factory.newDocumentBuilder(); // 解析XML文件 Document doc = builder.parse("file.xml"); // 获取根节点 Element root = doc.getDocumentElement(); // 遍历子节点 NodeList nodeList = root.getChildNodes(); for (int i = 0; i < nodeList.getLength(); i++) { Node node = nodeList.item(i); if (node.getNodeType() == Node.ELEMENT_NODE) { Element element = (Element) node; // 获取节点名称和值 System.out.println(element.getTagName() + ": " + element.getTextContent()); } } } catch (Exception e) { e.printStackTrace(); } } } ``` 这个示例代码使用DOM解析解析了名为"file.xml"的XML文档,并打印出每个子节点的名称和值。 ### 回答2: Java解析XML代码可以使用Java内置的API或者使用第三方库来进行操作。以下是使用Java内置的API解析XML的代码示例: ```java // 导入相关的包 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 XMLParser { public static void main(String[] args) { try { // 创建解析器工厂 DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); // 创建解析DocumentBuilder builder = factory.newDocumentBuilder(); // 解析XML文件 Document document = builder.parse("example.xml"); // 获取根节点 Element root = document.getDocumentElement(); // 获取子节点列表 NodeList nodeList = root.getChildNodes(); // 遍历子节点 for (int i = 0; i < nodeList.getLength(); i++) { Node node = nodeList.item(i); // 判断节点类型为元素节点 if (node.getNodeType() == Node.ELEMENT_NODE) { Element element = (Element) node; // 获取节点的标签名和内容 String tagName = element.getTagName(); String textContent = element.getTextContent(); // 输出节点信息 System.out.println("标签名:" + tagName); System.out.println("内容:" + textContent); System.out.println("----------------------------"); } } } catch (Exception e) { e.printStackTrace(); } } } ``` 以上示例代码使用了Java提供的XML解析器,首先创建解析器工厂和解析器,然后通过解析解析XML文件。接下来获取根节点和子节点列表,然后遍历子节点。在遍历过程中,判断节点类型为元素节点,然后获取节点的标签名和内容,并输出节点信息。 使用以上代码可以快速实现对XML文件的解析。当然,也可以考虑使用第三方库,如DOM4JJDOM或者SAX等。这些库提供了更多的灵活性和功能,可以根据需求选择合适的库来进行XML解析。 ### 回答3: Java解析XML是通过使用XML解析器来读取和解析XML文档的过程。 Java中有几种解析XML的方式,常用的有DOM和SAX两种。 DOM解析方式将整个XML文档加载到内存中的DOM树中,然后可以通过调用节点的方法来访问和操作XML元素和属性。使用DOM解析XML的步骤包括创建解析器、加载XML文档、获取根节点、遍历解析树,以及获取和操作节点的属性和元素等。DOM解析方式适用于需要对整个XML文档进行操作的场景,但是对大型XML文档解析可能会占用较多的内存空间。 SAX解析方式是事件驱动的,通过触发不同事件来处理XML文档中的数据。使用SAX解析XML的步骤包括创建解析器、实现事件处理方法、注册事件监听器,并通过解析解析XML文档SAX解析方式适用于对XML文档进行逐行处理的场景,它具有较低的内存消耗,但是相对DOM方式,编码复杂度较高。 不论使用哪种方式解析XML,都需要首先导入相关的解析器库,如使用DOM解析方式可以使用javax.xml.parsers包下的DocumentBuilder类,使用SAX解析方式可以使用org.xml.sax包下的SAXParser类。 写一个简单的XML解析程序示例: ```java 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 XMLParser { public static void main(String[] args) { try { DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); DocumentBuilder builder = factory.newDocumentBuilder(); Document doc = builder.parse("example.xml"); Element root = doc.getDocumentElement(); System.out.println("Root element: " + root.getNodeName()); NodeList nodeList = root.getChildNodes(); for (int i = 0; i < nodeList.getLength(); i++) { Node node = nodeList.item(i); if (node.getNodeType() == Node.ELEMENT_NODE) { Element element = (Element) node; System.out.println("Element: " + element.getNodeName()); System.out.println("Value: " + element.getTextContent()); } } } catch (Exception e) { e.printStackTrace(); } } } ``` 以上代码使用了DOM方式解析XML文档,首先创建解析器工厂、解析器和DOM文档对象,并指定需要解析XML文件路径,然后通过获取根节点和遍历子节点,打印出XML文档的节点名称和内容。 这只是一个简单的例子,实际应用中可能需要根据需要进行更复杂的XML解析操作。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

@SmartSi

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值