Java dom4j生成与解析XML案例详解

网友投稿 302 2022-12-16

Java dom4j生成与解析XML案例详解

一)dom4j介绍

使用方式:在pom.xml中导入dom4j对应的jar

dom4j

dom4j

1.6.1

优点: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(GQKqdSpNlJFile 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 attrs = http://element.attributes();

if (attrs != null) {

for (Attribute attr : attrs) {

buffer.append(" "+attr.getName()+"=\""+attr.getValue()+"\"");

}

}

buffer.append(">");

Iterator 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文件解析效果图打印:

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Java使用Servlet生成验证码图片
下一篇:java枚举类型
相关文章

 发表评论

暂时没有评论,来抢沙发吧~