dom4j解析xml

简介:

1.首先下载jar包

dom4j

2.解析xml文档

import Java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.InputStream;


import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;




public class Dom4jParseXmlDemo {
public void parseXml01(){
try {
//将src下的xml文件转换为输入流(两种方法导入)
// InputStream inputStream = new FileInputStream(new File("D:\\Workspaces\\MyEclipse 10\\Test\\src\\test.xml")) ;
InputStream inputStream = this.getClass().getResourceAsStream("/test.xml") ;
//创建SAXReader对象,读取xml
SAXReader saxReader = new SAXReader() ;
Document document = saxReader.read(inputStream) ;
Element rootElement = document.getRootElement() ;
System.out.println("根节点名称: " + rootElement.getName());
System.out.println("根节点有多少属性: " + rootElement.attributeCount());
System.out.println("根节点id属性的值: " + rootElement.attributeValue("id"));
//如果xml里面有换行,显示出来的文本也会换行
System.out.println("根节点内文本: " + rootElement.getText());
//去掉的是标签与标签之间的tab键和换行符等等,不是内容前后的空格
System.out.println("根节点内文本1: " + rootElement.getTextTrim());
//返回当前节点递归所有子节点的文本信息。
System.out.println("根节点子节点文本内容: " + rootElement.getStringValue());

Element element = rootElement.element("message") ;
if(element!=null){
System.out.println("子节点的文本: " + element.getText());
}
//修改节点名称和文本内容
rootElement.setName("root") ;
System.out.println("修改后的节点名称: " + rootElement.getName());
rootElement.setText("text") ;
System.out.println("根节点修改之后的文本: " + rootElement.getText());
}catch(DocumentException e){
e.printStackTrace() ;
}
}
public static void main(String[] args) {
Dom4jParseXmlDemo demo = new Dom4jParseXmlDemo() ;
demo.parseXml01() ;
}
}

上面的类在src下面,下面的test.xml也在src下面

<?xml version="1.0" encoding="UTF-8"?>  
<style id="2">  
这是文本
    <message>这是信息</message>
    <body>
    <message>这是信息2</message>
    </body>
</style> 

结果为:



3.获取document文档对象

import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.InputStream;
import java.util.Iterator;


import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;




public class Dom4jParseXmlDemo {
public void parseXml01(){
try {
//将src下的xml文件转换为输入流(两种方法导入)
// InputStream inputStream = new FileInputStream(new File("D:\\Workspaces\\MyEclipse 10\\Test\\src\\test.xml")) ;
InputStream inputStream = this.getClass().getResourceAsStream("/test.xml") ;
//创建SAXReader对象,读取xml
SAXReader saxReader = new SAXReader() ;
Document document = saxReader.read(inputStream) ;
Element rootElement = document.getRootElement() ;
Iterator<Element> it = rootElement.elements("body").iterator() ;
while(it.hasNext()){
Element bodyElement = it.next() ;
Element nameElement = bodyElement.element("name") ;
System.out.println(nameElement.getName() + ":" + nameElement.getText());
Element sexElement = bodyElement.element("sex") ;
System.out.println(sexElement.getName() + ":" + sexElement.getText());
Element addressElement = bodyElement.element("address") ;
System.out.println(addressElement.getName() + ":" + addressElement.getText());
}
}catch(DocumentException e){
e.printStackTrace() ;
}
}
public static void main(String[] args) {
Dom4jParseXmlDemo demo = new Dom4jParseXmlDemo() ;
demo.parseXml01() ;
}
}

下面是对应的xml文件

<?xml version="1.0" encoding="UTF-8"?>  
<style id="2">  
<body>
<name>wuhaixu</name>
<sex>nan</sex>
<address>beijing</address>
</body>
</style> 

结果为:


4.获取复杂的xml文档

xml文件

<?xml version="1.0" encoding="UTF-8"?>  
<style id="2">  
<chingcloud>问鼎清云</chingcloud>
<chingcloud id="a">
<name>mazhiyan</name>
<address>beijing</address>
<descript>网络科技有限公司</descript>
</chingcloud>
<chingcloud id="b">
<count>10</count>
<money>100</money>
<chingcloud id="1">
<name>wuhaixu</name>
<sex>nan</sex>
<age>22</age>
</chingcloud>
<chingcloud id="2">
<name>wangshihao</name>
<sex>nan</sex>
<age>20</age>
</chingcloud>  
</chingcloud>
</style> 

因为他们的结构不一样,直接迭代的话 会报错:

java.lang.NullPointerException

所以这个时候需要小心使用了,每次都不能把元素直接放进去迭代。具体实现代码如下:

java文件:

import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.InputStream;
import java.util.Iterator;
import java.util.List;


import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;




public class Dom4jParseXmlDemo {
public void parseXml01(){
try {
//将src下的xml文件转换为输入流(两种方法导入)
// InputStream inputStream = new FileInputStream(new File("D:\\Workspaces\\MyEclipse 10\\Test\\src\\test.xml")) ;
InputStream inputStream = this.getClass().getResourceAsStream("/test.xml") ;
//创建SAXReader对象,读取xml
SAXReader saxReader = new SAXReader() ;
Document document = saxReader.read(inputStream) ;
Element rootElement = document.getRootElement() ;
if(rootElement.elements("chingcloud") != null){
@SuppressWarnings("unchecked")
List<Element> elementList = rootElement.elements("chingcloud") ;
for(Element element:elementList){
if(!element.getTextTrim().equals("")){
System.out.println("【1】" + element.getTextTrim());
}else{
if(element.attributeValue("id").equals("a")){
Element nameElement = element.element("name") ;
System.out.println("  【2】" + nameElement.getName() + ":" + nameElement.getText());
Element addressElement = element.element("address") ;
System.out.println("  【2】" + addressElement.getName() + ":" + addressElement.getText());
Element descriptElement = element.element("descript") ;
System.out.println("  【2】" + descriptElement.getName() + ":" + descriptElement.getText());
}else if(element.attributeValue("id").equals("b")){
Element countElement = element.element("count") ;
System.out.println("    【3】" + countElement.getName() + ":" + countElement.getText());
Element moneyElement = element.element("money") ;
System.out.println("    【3】" + moneyElement.getName() + ":" + moneyElement.getText());
@SuppressWarnings("unchecked")
List<Element> subElements = element.elements("chingcloud") ;
int len = subElements.size() ;
for(int i=0;i<len;i++){
Element subElement = subElements.get(i) ;
Element nameSubElement = subElement.element("name") ;
System.out.println("      【" + (i+4) + "】" + nameSubElement.getName() + ":" + nameSubElement.getText()) ;
Element sexSubElement = subElement.element("sex") ;
System.out.println("      【" + (i+4) + "】" + sexSubElement.getName() + ":" + sexSubElement.getText()) ;
Element ageSubElement = subElement.element("age") ;
System.out.println("      【" + (i+4) + "】" + ageSubElement.getName() + ":" + ageSubElement.getText());
}
}

}
}
}
}catch(DocumentException e){
e.printStackTrace() ;
}
}
public static void main(String[] args) {
Dom4jParseXmlDemo demo = new Dom4jParseXmlDemo() ;
demo.parseXml01() ;
}
}

结果为:


5生成xml文档

import java.io.FileWriter;
import java.io.IOException;
import java.io.Writer;


import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.XMLWriter;




public class Dom4jBuildXmlDemo {
public void build01(){
Document document = DocumentHelper.createDocument() ;
Element rootElement = document.addElement("type") ;
rootElement.setText("这是type的文本信息") ;
Element subTypeElement = rootElement.addElement("subType") ;
Element nameElement = subTypeElement.addElement("name") ;
Element ageElement = subTypeElement.addElement("age") ;
Element sexElement = subTypeElement.addElement("sex") ;
nameElement.setText("张三") ;
ageElement.setText("22") ;
sexElement.setText("男") ;
nameElement.addAttribute("language", "java") ;
ageElement.addAttribute("language", "c#") ;
sexElement.addAttribute("language", "PHP") ;
System.out.println(document.asXML());
try {
Writer fileWriter = new FileWriter("d:\\test.xml") ;
XMLWriter xmlWriter = new XMLWriter(fileWriter) ;
xmlWriter.write(document) ;
xmlWriter.flush() ;
xmlWriter.close() ;
System.out.println("xml文档添加成功!");
} catch (IOException e) {
e.printStackTrace();
}
}
public static void main(String[] args) {
Dom4jBuildXmlDemo demo = new Dom4jBuildXmlDemo() ;
demo.build01() ;
}
}

结果为:

目录
相关文章
|
12月前
|
JavaScript 前端开发 Go
CSS 与 JS 对 DOM 解析和渲染的影响
【10月更文挑战第16天】CSS 和 JS 会在一定程度上影响 DOM 解析和渲染,了解它们之间的相互作用以及采取适当的优化措施是非常重要的。通过合理的布局和加载策略,可以提高网页的性能和用户体验,确保页面能够快速、流畅地呈现给用户。在实际开发中,要根据具体情况进行权衡和调整,以达到最佳的效果。
343 57
|
7月前
|
存储 Java 文件存储
微服务——SpringBoot使用归纳——Spring Boot使用slf4j进行日志记录—— logback.xml 配置文件解析
本文解析了 `logback.xml` 配置文件的详细内容,包括日志输出格式、存储路径、控制台输出及日志级别等关键配置。通过定义 `LOG_PATTERN` 和 `FILE_PATH`,设置日志格式与存储路径;利用 `&lt;appender&gt;` 节点配置控制台和文件输出,支持日志滚动策略(如文件大小限制和保存时长);最后通过 `&lt;logger&gt;` 和 `&lt;root&gt;` 定义日志级别与输出方式。此配置适用于精细化管理日志输出,满足不同场景需求。
1774 1
|
7月前
|
XML JavaScript Android开发
【Android】网络技术知识总结之WebView,HttpURLConnection,OKHttp,XML的pull解析方式
本文总结了Android中几种常用的网络技术,包括WebView、HttpURLConnection、OKHttp和XML的Pull解析方式。每种技术都有其独特的特点和适用场景。理解并熟练运用这些技术,可以帮助开发者构建高效、可靠的网络应用程序。通过示例代码和详细解释,本文为开发者提供了实用的参考和指导。
201 15
|
XML Web App开发 JavaScript
XML DOM 解析器
XML DOM 解析器
|
XML Web App开发 JavaScript
XML DOM 解析器
XML DOM 解析器
|
XML Java 数据格式
手动开发-简单的Spring基于XML配置的程序--源码解析
手动开发-简单的Spring基于XML配置的程序--源码解析
205 0
|
7月前
|
算法 测试技术 C语言
深入理解HTTP/2:nghttp2库源码解析及客户端实现示例
通过解析nghttp2库的源码和实现一个简单的HTTP/2客户端示例,本文详细介绍了HTTP/2的关键特性和nghttp2的核心实现。了解这些内容可以帮助开发者更好地理解HTTP/2协议,提高Web应用的性能和用户体验。对于实际开发中的应用,可以根据需要进一步优化和扩展代码,以满足具体需求。
685 29
|
7月前
|
前端开发 数据安全/隐私保护 CDN
二次元聚合短视频解析去水印系统源码
二次元聚合短视频解析去水印系统源码
205 4
|
7月前
|
JavaScript 算法 前端开发
JS数组操作方法全景图,全网最全构建完整知识网络!js数组操作方法全集(实现筛选转换、随机排序洗牌算法、复杂数据处理统计等情景详解,附大量源码和易错点解析)
这些方法提供了对数组的全面操作,包括搜索、遍历、转换和聚合等。通过分为原地操作方法、非原地操作方法和其他方法便于您理解和记忆,并熟悉他们各自的使用方法与使用范围。详细的案例与进阶使用,方便您理解数组操作的底层原理。链式调用的几个案例,让您玩转数组操作。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
7月前
|
移动开发 前端开发 JavaScript
从入门到精通:H5游戏源码开发技术全解析与未来趋势洞察
H5游戏凭借其跨平台、易传播和开发成本低的优势,近年来发展迅猛。接下来,让我们深入了解 H5 游戏源码开发的技术教程以及未来的发展趋势。

推荐镜像

更多
  • DNS