使用Dom4j 来创建 读取 修改 删除 打印 格式化 XML文档
//加入下面两个包
D:\Soft\jar\dom4j-1.6.1.jar
D:\Soft\jar\jaxen.jar
//开始
package com.itheima.xml;
import java.io.File;
import java.io.FileOutputStream;
import java.io.FileWriter;
import java.io.IOException;
import java.util.Iterator;
import java.util.List;
import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;
public class TextDom4jParseXML {
/**
* @param args
* @throws DocumentException
* @throws IOException
*/
public static void main(String[] args) throws IOException, DocumentException {
String filename="F:/test.xml"; //不存在的文件
System.out.println("============1.创建文档");
if (createXMLFile(filename)==1)
System.out.println("创建XML文档成功!");
else
System.out.println("创建XML文件失败!");
System.out.println("=============2.读取XML文件,将文档内容输出到控制台");
read(getDocument(filename));
System.out.println();
System.out.println("=============3.修改XML文档内容,输出修改后的文档内容");
update(filename, "songshu", "liushu");
toControl(filename, getDocument(filename)); //输出修改后的文档,然后保存修改后的文档
System.out.println("============4.删除编号为002的节点,输出删除后的文件");
delete(filename, "002");
toControl(filename, getDocument(filename));
System.out.println("============5.输出节点(/trees/tree)");
print(filename);
System.out.println("============6.格式化文件解决中文问题");
if(formatXML(filename, "GBk")==1){
System.out.println("格式化文档成功!");
}else
System.out.println("格式化失败!");
}
//手动创建一个XML文件 输出到制定的文件下
public static int createXMLFile(String filename){
int returnVale=0; //返回操作的结果 0 表示失败, 1表示成功
//创建XML文件
Document document=DocumentHelper.createDocument();
//创建根节点
Element treesElement=document.addElement("trees");
treesElement.addComment("This is a test for dom4j"); //加入一行注释
//加入 第一个tree节点
Element treeElement=treesElement.addElement("tree");
treeElement.addAttribute("id","001"); //添加id属性内容
treeElement.addAttribute("name", "rongshu"); //添加 name属性内容
Element descElement=treeElement.addElement("description");
descElement.setText("It is a big tree"); //为 descriiption 设置内容
//添加第二个节点
treeElement=treesElement.addElement("tree");
treeElement.addAttribute("id", "002");
treeElement.addAttribute("name", "yangshu");
descElement=treeElement.addElement("description");
descElement.setText("The tree grows taller form day to day");
//添加第三个节点
treeElement=treesElement.addElement("tree");
treeElement.addAttribute("id", "003");
treeElement.addAttribute("name", "songshu");
descElement=treeElement.addElement("description");
descElement.setText("The tree is very beautiful");
Element ownerElement=treesElement.addElement("flower");
ownerElement.setText("rose");
try {
//创建XML文件对象
XMLWriter writer=new XMLWriter(new FileWriter(new File(filename)));
writer.write(document);
writer.close();
returnVale=1;
} catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
}
return returnVale;
}
public static void read(Document document) throws IOException{
XMLWriter writer=new XMLWriter(new FileWriter("F:/output.xml"));
writer.write(document);
writer.close();
//将文件内容缩进方式输出到控制台
OutputFormat format=OutputFormat.createPrettyPrint();
writer=new XMLWriter(System.out, format);
writer.write(document);
//讲文件内容紧凑的输出到控制台
format=OutputFormat.createCompactFormat();
writer =new XMLWriter(System.out, format);
writer.write(document);
}
//读取文件获取document
public static Document getDocument(String filename) throws DocumentException{
SAXReader saxReader=new SAXReader();
Document document=saxReader.read(new File(filename));
return document;
}
//删除 XML文件中指定的id节点
public static boolean delete(String filename,String id) throws DocumentException{
boolean returnValue=false;
Document document=getDocument(filename); //调用方法获取document
Element root=document.getRootElement(); //获得根节点
List list=document.selectNodes("/trees/tree/@id"); //获取编号的列表
Iterator iter=list.iterator();
while (iter.hasNext()) {
Attribute attribute=(Attribute)iter.next();
if(attribute.getValue().equals(id)){
Element element=attribute.getParent();
root.remove(element);
}
}
try {
XMLWriter writer=new XMLWriter(new FileOutputStream(new File(filename)));
writer.write(document);
writer.close();
returnValue=true;
} catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
return returnValue;
}
return returnValue;
}
//修改xml文件中的指定的节点内容 ,并且 添加内容
public static int update(String filename,String oldName,String newName){
int returnValue=0;
try {
Document document=getDocument(filename);
List list=document.selectNodes("/trees/tree/@name");
Iterator iter=list.iterator();
while (iter.hasNext()) {
Attribute attribute = (Attribute)iter.next();
if(attribute.getValue().equals(oldName)){
attribute.setValue(newName);
}
}
list=document.selectNodes("/trees/flower");
iter=list.iterator();
if(iter.hasNext()){
Element flower=(Element)iter.next();
flower.setText("lily");
Element date=flower.addElement("date");
date.setText("2009-04-10");
date.addAttribute("type", "calendar");
}
try {
XMLWriter writer=new XMLWriter(new FileWriter(new File(filename)));
writer.write(document);
writer.close();
returnValue=1;
} catch (Exception e) {
// TODO: handle exception
System.out.println("修改XML文件出错:"+e.getMessage());
returnValue=0;
}
} catch (Exception e) {
System.out.println("修改XML文件出错:"+e.getMessage());
returnValue=0;
}
return returnValue;
}
//格式化XML文档并且解决中文乱码
public static int formatXML(String filename,String encoding){
int returnValue=0;
try {
Document document=getDocument(filename);
XMLWriter writer=null;
//格式化输出,类型和ID浏览一样
OutputFormat format=OutputFormat.createPrettyPrint();
format.setEncoding(encoding); //指定XML的编码方式
writer=new XMLWriter(new FileWriter(new File(filename)),format);
writer.write(document);
writer.close();
returnValue=1;
} catch (Exception e) {
System.out.println("格式化XML文档出错:"+e.getMessage());
returnValue=0;
}
return returnValue;
}
public static void toControl(String filename,Document document){
try {
XMLWriter writer=new XMLWriter(new FileWriter(filename));
writer.write(document); //将文档内容输出到文件
writer.close();
//将文档内容格式化输出到控制台
OutputFormat format=OutputFormat.createPrettyPrint();
writer=new XMLWriter(System.out,format);
writer.write(document);
} catch (Exception e) {
// TODO: handle exception
System.out.println("输出出错:"+e.getMessage());
}
}
//将xml转化成String
public static String XmlToString(Document document){
return document.asXML();
}
//将String 转换成 document
public static Document StrintToDocument(String text){
try {
return DocumentHelper.parseText(text);
} catch (Exception e) {
System.out.println("转换出错:"+e.getMessage());
return null;
}
}
//输出节点
public static void print(String filename){
try {
Document doc=getDocument(filename);
Node node=doc.selectSingleNode("/trees/tree");
System.out.println("输出节点:"+node.asXML()); //将节点转化成String
} catch (Exception e) {
// TODO: handle exception
System.out.println("输出节点出错:"+e.getMessage());
}
}
}
分享到:
相关推荐
在“dom4j解析xml文件(增删改查)”这个主题中,我们将深入探讨如何使用DOM4J来实现XML文档的四种基本操作:增加元素、删除元素、更新元素内容以及查询元素。 首先,让我们了解DOM4J的基本用法。在解析XML文件时,...
5. **事件驱动解析(SAX)**:除了传统的DOM解析外,DOM4J还支持SAX解析器,这种解析方式适用于处理大型XML文件,因为它不需要一次性加载整个文档到内存。 6. **Namespace支持**:DOM4J提供了对XML命名空间的全面...
### DOM4J解析XML详解 #### 一、DOM4J简介与特性 DOM4J是一个由dom4j.org开发的开源XML解析包,专为Java平台设计,它不仅支持DOM、SAX和JAXP标准,还巧妙地融入了Java集合框架,使其成为Java开发者在处理XML数据时...
在本示例中,我们将深入探讨如何使用DOM4J解析XML文件,以`CacheInit.java`作为我们的核心代码示例,并参考`emailTemplateConfig.xml`作为实际操作的对象。 首先,让我们了解XML(eXtensible Markup Language)。...
"以及解析xml文档所用的pdf文档说明"则表明还有一个PDF文档,可能详细介绍了如何使用dom4j来解析XML文件,包括各种方法、类和接口的使用示例。 **dom4j解析XML文档知识点:** 1. **dom4j简介**:dom4j是一个开放...
本篇文章将深入探讨如何使用DOM4J来解析XML文件,以及通过示例代码来展示其基本操作。 首先,我们需要理解DOM4J的工作原理。DOM4J采用的是DOM(Document Object Model)模型,它将整个XML文档加载到内存中形成一棵...
以下是如何使用DOM4j解析XML: 1. 引入DOM4j库(如:dom4j-1.6.1.jar)。 2. 创建DocumentFactory实例。 3. 使用DocumentFactory的read()方法读取XML文件,得到Document对象。 4. 使用Document对象提供的方法(如...
在使用DOM4j解析XML文件时,首先需要导入DOM4j的相关包,如`SAXReader`用于读取XML文件,`Document`表示整个XML文档,`Element`表示XML文档中的元素,以及`Attribute`表示元素的属性。以下是一个使用DOM4j解析XML...
DOM4J是一个强大的Java库,专门用于解析XML文档。它提供了简单易用的API,使得开发者可以更加方便地处理XML数据。DOM4J的核心优势在于它的面向接口编程设计,这使得它能够在不同的解析机制间灵活切换,如DOM、SAX和...
通过这种方式,我们可以利用DOM4J解析XML文件,同时借助Java反射机制将解析结果动态地映射到自定义的Java类中。这在处理XML数据时提供了很大的灵活性,尤其在需要将XML数据与业务对象关联时,反射机制显得尤为重要。
1、xml文档解析 2、 dom4j解析xml 3、实现xml文件解析 xml字符串解析 xml MAP键值对解析 4、实现xml写入与生成文件
在这个实例中,我们将深入探讨如何使用DOM4J解析XML文件,并通过`Dom4jTest1.java`这个示例程序来理解其工作原理。 首先,我们需要了解XML(Extensible Markup Language)是一种标记语言,常用于存储和传输数据。...
以下是一个DOM4J解析XML的简单示例: ```java import org.dom4j.Document; import org.dom4j.DocumentHelper; import org.dom4j.Element; public class Dom4jExample { public static void main(String[] args) {...
Java DOM4J解析XML是一种常见的处理XML文档的技术,它提供了灵活且高效的API,使得开发者能够方便地读取、写入、修改以及操作XML文件。DOM4J是Java中一个非常强大的XML处理库,它结合了DOM、SAX和JDOM的优点,同时也...
要开始解析XML文件,首先需要导入DOM4J的相关包: ```java import org.dom4j.Document; import org.dom4j.DocumentException; import org.dom4j.Element; import org.dom4j.io.SAXReader; ``` 接下来,我们将创建...
**DOM4J解析XML** DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了灵活、高效且功能丰富的API,使得XML的读取、创建、修改和查询变得简单易行。DOM4J的主要特点包括对XPath的支持、事件驱动的解析、以及与...
**DOM4J解析XML实例详解** 在Java编程中,处理XML文档是一项常见的任务。DOM4J是一个非常流行的、强大的Java XML API,它提供了灵活且高效的方式来解析、创建、修改XML文档。本文将深入探讨如何使用DOM4J进行XML...
### DOM4J解析XML知识点详解 #### 一、DOM4J简介 DOM4J是一个Java库,用于处理XML文档。它的设计目标是为了提供一个简单、易于使用的API来处理XML文件,同时保持性能上的优势。与Java标准库中的DOM实现相比,DOM4J...
DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了灵活且高效的API,使得XML的解析、创建、修改和查询变得简单。DOM4J的名字来源于DOM(Document Object Model)和Java的结合,但它的设计理念比标准DOM更先进...