dom4j解析和生成XML文件

2024-06-05 08:38
文章标签 xml 生成 解析 dom4j

本文主要是介绍dom4j解析和生成XML文件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

转化XML

import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.io.SAXReader;public class Foo {public Document parse(URL url) throws DocumentException {SAXReader reader = new SAXReader();Document document = reader.read(url);return document;}
}

使用迭代器

document可以通过几个返回Java标准迭代器的方法实现遍历:

public void bar(Document document) throws DocumentException {Element root = document.getRootElement();// iterate through child elements of rootfor ( Iterator i = root.elementIterator(); i.hasNext(); ) {Element element = (Element) i.next();// do something}// iterate through child elements of root with element name "foo"for ( Iterator i = root.elementIterator( "foo" ); i.hasNext(); ) {Element foo = (Element) i.next();// do something}// iterate through attributes of root for ( Iterator i = root.attributeIterator(); i.hasNext(); ) {Attribute attribute = (Attribute) i.next();// do something}}

快速循环

快速遍历大文件:

public void treeWalk(Document document) {treeWalk( document.getRootElement() );}public void treeWalk(Element element) {for ( int i = 0, size = element.nodeCount(); i < size; i++ ) {Node node = element.node(i);if ( node instanceof Element ) {treeWalk( (Element) node );}else {// do something....}}}

创建XML文档

import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;public class Foo {public Document createDocument() {Document document = DocumentHelper.createDocument();Element root = document.addElement( "root" );Element author1 = root.addElement( "author" ).addAttribute( "name", "James" ).addAttribute( "location", "UK" ).addText( "James Strachan" );Element author2 = root.addElement( "author" ).addAttribute( "name", "Bob" ).addAttribute( "location", "US" ).addText( "Bob McWhirter" );return document;}
}

将文档写入文件

一种快速而且简单的方式如下:

FileWriter out = new FileWriter( "foo.xml" );
document.write( out );

如果想要修改输出的格式,如智能缩进输出或者紧凑输出,或者你想要使用writer对象或者OutputStream对象来完成其他任务,则可以使用XMLWriter类。

import org.dom4j.Document;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.XMLWriter;public class Foo {public void write(Document document) throws IOException {// lets write to a fileXMLWriter writer = new XMLWriter(new FileWriter( "output.xml" ));writer.write( document );writer.close();// Pretty print the document to System.outOutputFormat format = OutputFormat.createPrettyPrint();writer = new XMLWriter( System.out, format );writer.write( document );// Compact format to System.outformat = OutputFormat.createCompactFormat();writer = new XMLWriter( System.out, format );writer.write( document );}
}

与String的转化

如果有到Document或者其他结点如AttributeElement等的引用,则可以用asXML()方法将其转化为默认的XML文本。

Document document = ...;
String text = document.asXML();

如果有String形式的XML,则可以使用DocumentHelper.parseText()将其转化为Document

String text = "<person> <name>James</name> </person>";
Document document = DocumentHelper.parseText(text);

其他操作

1 取得某结点下的某个子节点或属性

Element root = document.getRootElement();
Element elem = root.element("book");
Attribute attribute = root.attribute("id");

2 取得属性的内容

String text = attribute.getText();

3 删除某属性

Attribute attribute=root.attribute("id"); 
root.remove(attribute);

一个完整的解析和生成XML文件示例

package test;import java.io.*;
import java.util.Iterator;
import java.util.List;
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;
import org.dom4j.Attribute;class XMLHelper {/*** 解析XML* @param filename 要解析的XML的文件名*/public static void resolveXML(String filename) {try {SAXReader reader = new SAXReader();Document document = reader.read(new File(filename));Element root = document.getRootElement();System.out.println("Root: " + root.getName());for (Iterator it = root.elementIterator(); it.hasNext(); ) {Element e = (Element)it.next();System.out.print(e.getName());//遍历属性for (Iterator it1 = e.attributeIterator(); it1.hasNext(); ) {Attribute attribute = (Attribute)it1.next();System.out.println("[" + attribute.getName() + ": " +attribute.getText() + "]");}//遍历子节点for (Iterator it2 = e.elementIterator(); it2.hasNext(); ) {Element ee = (Element)it2.next();System.out.println("    " + ee.getName() + ": " + ee.getText() + " ");}}} catch (Exception ex) {ex.printStackTrace();}}public static Document createDocument() {Document document = DocumentHelper.createDocument();Element root = document.addElement("bookstore");//add bookElement book = root.addElement("book").addAttribute("category", "COOKING");book.addElement("title").addText("Everyday Italian");book.addElement("author").addText("Giada De Laurentiis");book.addElement("year").addText("2005");book.addElement("price").addText("30.00");//add bookbook = root.addElement("book").addAttribute("category", "CHILDREN");book.addElement("title").addText("Harry Potter");book.addElement("author").addText("J K. Rowling");book.addElement("year").addText("2005");book.addElement("price").addText("29.99");return document;}/*** 生成XML文件* @param filename 将生成的XML输出到该文件*/public static void write(String filename) {Document document = createDocument(); try {//write to a fileOutputFormat f=OutputFormat.createPrettyPrint();XMLWriter writer = new XMLWriter(new FileWriter(filename), f);writer.write(document);writer.close();//Pretty print the document to System.out/*OutputFormat format = OutputFormat.createPrettyPrint();writer = new XMLWriter(System.out, format);writer.write(document);*///Compact print the document to System.out/*format = OutputFormat.createCompactFormat();writer = new XMLWriter(System.out, format);writer.write(document);*/} catch (Exception ex) {ex.printStackTrace();}}
}public class Main {public static void main(String[] args) throws Exception{String filename = "E:\\Eclipse Project\\WebTest\\WebContent\\myxml.xml";XMLHelper.resolveXML(filename);filename = "E:\\Eclipse Project\\WebTest\\WebContent\\myxml2.xml";XMLHelper.write(filename);}
}

这篇关于dom4j解析和生成XML文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1032598

相关文章

C#中读取XML文件的四种常用方法

《C#中读取XML文件的四种常用方法》Xml是Internet环境中跨平台的,依赖于内容的技术,是当前处理结构化文档信息的有力工具,下面我们就来看看C#中读取XML文件的方法都有哪些吧... 目录XML简介格式C#读取XML文件方法使用XmlDocument使用XmlTextReader/XmlTextWr

浅析如何使用Swagger生成带权限控制的API文档

《浅析如何使用Swagger生成带权限控制的API文档》当涉及到权限控制时,如何生成既安全又详细的API文档就成了一个关键问题,所以这篇文章小编就来和大家好好聊聊如何用Swagger来生成带有... 目录准备工作配置 Swagger权限控制给 API 加上权限注解查看文档注意事项在咱们的开发工作里,API

C语言中自动与强制转换全解析

《C语言中自动与强制转换全解析》在编写C程序时,类型转换是确保数据正确性和一致性的关键环节,无论是隐式转换还是显式转换,都各有特点和应用场景,本文将详细探讨C语言中的类型转换机制,帮助您更好地理解并在... 目录类型转换的重要性自动类型转换(隐式转换)强制类型转换(显式转换)常见错误与注意事项总结与建议类型

Java使用POI-TL和JFreeChart动态生成Word报告

《Java使用POI-TL和JFreeChart动态生成Word报告》本文介绍了使用POI-TL和JFreeChart生成包含动态数据和图表的Word报告的方法,并分享了实际开发中的踩坑经验,通过代码... 目录前言一、需求背景二、方案分析三、 POI-TL + JFreeChart 实现3.1 Maven

MySQL 缓存机制与架构解析(最新推荐)

《MySQL缓存机制与架构解析(最新推荐)》本文详细介绍了MySQL的缓存机制和整体架构,包括一级缓存(InnoDBBufferPool)和二级缓存(QueryCache),文章还探讨了SQL... 目录一、mysql缓存机制概述二、MySQL整体架构三、SQL查询执行全流程四、MySQL 8.0为何移除查

在Rust中要用Struct和Enum组织数据的原因解析

《在Rust中要用Struct和Enum组织数据的原因解析》在Rust中,Struct和Enum是组织数据的核心工具,Struct用于将相关字段封装为单一实体,便于管理和扩展,Enum用于明确定义所有... 目录为什么在Rust中要用Struct和Enum组织数据?一、使用struct组织数据:将相关字段绑

使用Java实现一个解析CURL脚本小工具

《使用Java实现一个解析CURL脚本小工具》文章介绍了如何使用Java实现一个解析CURL脚本的工具,该工具可以将CURL脚本中的Header解析为KVMap结构,获取URL路径、请求类型,解析UR... 目录使用示例实现原理具体实现CurlParserUtilCurlEntityICurlHandler

深入解析Spring TransactionTemplate 高级用法(示例代码)

《深入解析SpringTransactionTemplate高级用法(示例代码)》TransactionTemplate是Spring框架中一个强大的工具,它允许开发者以编程方式控制事务,通过... 目录1. TransactionTemplate 的核心概念2. 核心接口和类3. TransactionT

数据库使用之union、union all、各种join的用法区别解析

《数据库使用之union、unionall、各种join的用法区别解析》:本文主要介绍SQL中的Union和UnionAll的区别,包括去重与否以及使用时的注意事项,还详细解释了Join关键字,... 目录一、Union 和Union All1、区别:2、注意点:3、具体举例二、Join关键字的区别&php

Spring IOC控制反转的实现解析

《SpringIOC控制反转的实现解析》:本文主要介绍SpringIOC控制反转的实现,IOC是Spring的核心思想之一,它通过将对象的创建、依赖注入和生命周期管理交给容器来实现解耦,使开发者... 目录1. IOC的基本概念1.1 什么是IOC1.2 IOC与DI的关系2. IOC的设计目标3. IOC