大家好,又见面了,我是你们的朋友全栈君。
一)dom4j介绍
使用方式:在pom.xml中导入dom4j对应的jar
<dependency>
<groupId>dom4j</groupId>
<artifactId>dom4j</artifactId>
<version>1.6.1</version>
</dependency>
优点:dom4j使Java生成和解析XML灵活性变高,并且代码易于维护
API操作类:
Document:表示xml文档信息,是一个树形结构
Eelment:表示xml的元素结点,提供一些操作其子元素方法的,如文本、属性、名称空间等
Attribute:表示元素结点中的属性
二)dom4j生成xml
实现步骤:
第一步:创建一个Document实例
Document doc = DocumentHelper.createDocument();
第二步:先添加一个根结点,然后再添加子结点,构造成一个树形结构
Element root = doc.addElement(“root”);
第三步:添加xml文件样式(也可自定义样式),并输出xml文件到指定的路径下
OutputFormat format = OutputFormat.createPrettyPrint();
XMLWriter writer = new XMLWriter(new FileOutputStream(file), format);
writer.write(doc);
实现源码:
package com.oysept.xml;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.XMLWriter;
import org.jdom2.output.Format;
/**
* dom4j生成xml
* @author ouyangjun
*/
public class CreateDom4j {
public static void main(String[] args) {
// 执行dom4j生成xml方法
createDom4j(new File("E:\\dom4j.xml"));
}
public static void createDom4j(File file) {
try {
// 创建一个Document实例
Document doc = DocumentHelper.createDocument();
// 添加根节点
Element root = doc.addElement("root");
// 在根节点下添加第一个子节点
Element oneChildElement= root.addElement("person").addAttribute("attr", "root noe");
oneChildElement.addElement("people")
.addAttribute("attr", "child one")
.addText("person one child one");
oneChildElement.addElement("people")
.addAttribute("attr", "child two")
.addText("person one child two");
// 在根节点下添加第一个子节点
Element twoChildElement= root.addElement("person").addAttribute("attr", "root two");
twoChildElement.addElement("people")
.addAttribute("attr", "child one")
.addText("person two child one");
twoChildElement.addElement("people")
.addAttribute("attr", "child two")
.addText("person two child two");
// xml格式化样式
// OutputFormat format = OutputFormat.createPrettyPrint(); // 默认样式
// 自定义xml样式
OutputFormat format = new OutputFormat();
format.setIndentSize(2); // 行缩进
format.setNewlines(true); // 一个结点为一行
format.setTrimText(true); // 去重空格
format.setPadText(true);
format.setNewLineAfterDeclaration(false); // 放置xml文件中第二行为空白行
// 输出xml文件
XMLWriter writer = new XMLWriter(new FileOutputStream(file), format);
writer.write(doc);
System.out.println("dom4j CreateDom4j success!");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
}
XML文件效果图:
三)dom4j解析xml
实现步骤:
第一步:创建一个SAXReader解析器
SAXReader reader = new SAXReader();
第二步:解析xml文件,重新构建成一个Document对象
Document doc = reader.read(file);
第三步:处理Document对象信息,在控制台打印
实现源码:
package com.oysept.xml;
import java.io.File;
import java.util.Iterator;
import java.util.List;
import org.dom4j.Attribute;
import org.dom4j.CDATA;
import org.dom4j.Comment;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.Text;
import org.dom4j.io.SAXReader;
/**
* dom4j解析xml
* @author ouyangjun
*/
public class ParseDom4j {
public static void main(String[] args) {
// 执行dom4j解析xml方法
parseDom4j(new File("E:\\dom4j.xml"));
}
public static void parseDom4j(File file) {
try {
// 创建一个SAXReader解析器
SAXReader reader = new SAXReader();
// 读取xml文件,转换成Document结点
Document doc = reader.read(file);
// 递归打印xml文档信息
StringBuffer buffer = new StringBuffer();
parseElement(doc.getRootElement(), buffer);
System.out.println(buffer.toString());
} catch (DocumentException e) {
e.printStackTrace();
}
}
@SuppressWarnings("unchecked")
public static void parseElement(Element element, StringBuffer buffer) {
buffer.append("<"+element.getName());
List<Attribute> attrs = element.attributes();
if (attrs != null) {
for (Attribute attr : attrs) {
buffer.append(" "+attr.getName()+"=\""+attr.getValue()+"\"");
}
}
buffer.append(">");
Iterator<Node> iterator = element.nodeIterator();
while (iterator.hasNext()) {
Node node = iterator.next();
if (node instanceof Element) {
Element eleNode = (Element) node;
parseElement(eleNode, buffer);
}
if (node instanceof Text) {
Text text = (Text) node;
buffer.append(text.getText());
}
if (node instanceof CDATA) {
CDATA dataNode = (CDATA) node;
buffer.append(dataNode.getText());
}
if (node instanceof Comment) {
Comment comNode = (Comment) node;
buffer.append(comNode.getText());
}
}
buffer.append("</"+element.getName()+">");
}
}
XML文件解析效果图打印:
识别二维码关注个人微信公众号
本章完结,待续,欢迎转载!
本文说明:该文章属于原创,如需转载,请标明文章转载来源!
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/152048.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...