一、简介
dom4j是一个Java的XML API,类似于jdom,用来读写XML文件的。dom4j是一个非常非常优秀的Java XML API,具有性能优异、功能强大和极端易用使用的特点,同时它也是一个开放源代码的软件,可以在SourceForge上找到它。
使用Dom4j开发,需下载dom4j相应的jar文件
1、官网下载:http://www.dom4j.org/dom4j-1.6.1/
2、dom4j是sourceforge.net上的一个开源项目,因此可以到http://sourceforge.net/projects/dom4j下载其最新版.
二、实例(解析xml)
1、dom4j.xml文件内容,如下:
<?xml version="1.0" encoding="UTF-8"?>
<books>
<xiyouji id="x001">
<author>吴承恩</author>
<times>明朝</times>
</xiyouji>
<hongloumeng id="x002">
<author>曹雪芹</author>
</hongloumeng>
</books>
2、测试类
package com.test;
import java.io.File;
import java.io.FileOutputStream;
import java.io.OutputStreamWriter;
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.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;
public class TestDOM4JForXML {
public static void main(String[] args) throws Exception {
TestDOM4JForXML.readXML("dom4j.xml");
TestDOM4JForXML.updateXML("dom4j.xml");
}
/**
* 获取document对象
*/
public static Document getDocument(String fileName) {
SAXReader saxReader = new SAXReader();
Document document = null;
try {
document = saxReader.read(new File(fileName));// 通过read方法读取一个文件,转换成Document对象
} catch (DocumentException e) {
e.printStackTrace();
}
return document;
}
/**
* 读取xml文件的内容
*/
public static void readXML(String fileName) throws Exception {
Document document = getDocument(fileName);
Element node = document.getRootElement(); // 获取根节点元素对象
listNodes(node);
}
public static void listNodes(Element node) {
System.out.println("节点名称:" + node.getName()); //获取当前节点的名称
List<Attribute> list = node.attributes(); // 获取当前节点的所有属性节点
for (Attribute attr : list) { // 遍历属性节点
System.out.println(attr.getText() + "-----" + attr.getName() + "---" + attr.getValue());
}
if (!(node.getTextTrim().equals(""))) {
System.out.println("文本内容:" + node.getText());
}
Iterator<Element> it = node.elementIterator(); // 当前节点下面子节点迭代器
while (it.hasNext()) {
Element e = it.next(); // 获取某个子节点对象
listNodes(e); // 对子节点进行遍历
}
}
/**
* 修改xml文件的内容
*/
public static void updateXML(String fileName) throws Exception {
Document document = getDocument(fileName);
Element node = document.getRootElement(); // 获取根节点元素对象
Element element = node.element("hongloumeng"); // 获取books元素节点中,子节点名称为hongloumeng元素节点。
Attribute attr = element.attribute("id"); // 获取element的id属性节点对象
element.remove(attr); // 删除属性
element.addAttribute("name", "作者"); // 添加新的属性
Element newElement = element.addElement("朝代"); // 在hongloumeng元素节点中添加朝代元素的节点
newElement.setText("清朝"); // 获取element中的作者元素节点对象
Element author = element.element("作者");
boolean flag = element.remove(author); // 删除元素节点 (返回true代码删除成功,否则失败 )
Element descElement = element.addElement("简介");
descElement.addCDATA("红楼梦,是一部爱情小说。"); //添加CDATA区域
writer(document);
}
/**
* 把document对象写入新的文件
*/
public static void writer(Document document) throws Exception {
// OutputFormat format = OutputFormat.createCompactFormat(); // 紧凑的格式
OutputFormat format = OutputFormat.createPrettyPrint(); // 排版缩进的格式
format.setEncoding("UTF-8"); // 设置编码
// 创建XMLWriter对象,指定了写出文件及编码格式
// XMLWriter writer = new XMLWriter(new FileWriter(new File("dom4j.xml")),format);
XMLWriter writer = new XMLWriter(new OutputStreamWriter( new FileOutputStream(new File("dom4j.xml")), "UTF-8"), format);
writer.write(document); // 写入
writer.flush(); // 立即写入
writer.close(); // 关闭操作
}
}
三、实例(字符串与XML互转换)
package com.test;
import java.io.File;
import java.io.FileOutputStream;
import java.io.FileWriter;
import java.io.OutputStreamWriter;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;
public class TestParseXML {
public static void main(String[] args) throws Exception {
TestParseXML.parseXML();
TestParseXML.updateXML();
TestParseXML.readXML();
}
/**
* 获取document对象
*/
public static Document getDocument(String fileName) {
SAXReader saxReader = new SAXReader();
Document document = null;
try {
document = saxReader.read(new File(fileName));// 通过read方法读取一个文件,转换成Document对象
} catch (DocumentException e) {
e.printStackTrace();
}
return document;
}
/**
* 把一个文本字符串转换Document对象
*/
public static void parseXML() throws Exception {
String text = "<csdn><java>Java班</java><net>Net班</net></csdn>";
Document document = DocumentHelper.parseText(text);
writer(document);
}
/**
* 创建一个document对象 往document对象中添加节点元素 转存为xml文件
*/
public static void updateXML() throws Exception {
Document document = DocumentHelper.createDocument(); // 创建根节点
Element root = document.addElement("csdn");
Element java = root.addElement("java");
java.setText("java班");
Element ios = root.addElement("ios");
ios.setText("ios班");
writer(document);
}
public static void readXML() {
Document document = getDocument("csdn.xml");
Element root = document.getRootElement();
String docXmlText = document.asXML(); // 把文档转换字符串
System.out.println(docXmlText);
System.out.println("---------------------------");
String rootXmlText = root.asXML(); // books元素标签根转换的内容
System.out.println(rootXmlText);
System.out.println("--------------------------");
Element e = root.element("java"); // 获取hongloumeng元素标 内的内容
System.out.println(e.asXML());
}
/**
* 把document对象写入新的文件
*/
public static void writer(Document document) throws Exception {
// OutputFormat format = OutputFormat.createCompactFormat(); // 紧凑的格式
OutputFormat format = OutputFormat.createPrettyPrint(); // 排版缩进的格式
format.setEncoding("UTF-8"); // 设置编码
// 创建XMLWriter对象,指定了写出文件及编码格式
// XMLWriter writer = new XMLWriter(new FileWriter(new File("csdn.xml")),format);
XMLWriter writer = new XMLWriter(new OutputStreamWriter( new FileOutputStream(new File("csdn.xml")), "UTF-8"), format);
writer.write(document); // 写入
writer.flush(); // 立即写入
writer.close(); // 关闭操作
}
}
原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/16353.html