`
gaozengguang
  • 浏览: 63464 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

dom4j解析xml学习笔记

阅读更多

      对于dom4j我是在今年暑假接触的.今天我想把xml文件解析成JAVA对象.

1、下载dom4j-1.6.1.jar包。

2、新建一工程web。在WebContent目录下创建users.xml文件

<?xml version="1.0" encoding="UTF-8"?>
<root>
  <users>
    <user name="ddd" mail="renyi@renyi.com" age="20"/>
    <user name="ddd" mail="renyi@renyi.com" age="20"/>
    <user name="ddd" mail="renyi@renyi.com" age="20"/>
    <user name="ddd" mail="renyi@renyi.com" age="20"/>
    <user name="ddd" mail="renyi@renyi.com" age="20"/>
  </users>
</root>

3、创建一个Bean——ElementNode.java

package com.test.learn_xml.dto;

import org.dom4j.Element;

public class ElementNode 
{
	private Element element;
	private String  id;//唯一标示符
	private String  parentId;//父节点ID
	public Element getElement() {
		return element;
	}
	public void setElement(Element element) {
		this.element = element;
	}
	public String getId() {
		return id;
	}
	public void setId(String id) {
		this.id = id;
	}
	public String getParentId() {
		return parentId;
	}
	public void setParentId(String parentId) {
		this.parentId = parentId;
	}
}

 

4、创建一个class——main.java

package com.inspur.learn_xml.action;

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;

import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;

import com.test.learn_xml.dto.ElementNode;

public class do4jMain {

	/**
	 * @param args
	 */
	static int num = 0;
	static List<ElementNode> elementNodes = new ArrayList<ElementNode>();
	public static void main(String[] args) 
	{
		String fileUrl = "WebContent/xml/users.xml";
		readModels(fileUrl);
		showElements();
		fileUrl = "WebContent/xml/test.xml";
		createXmlDoc(fileUrl);
	}
	public static void readModels(String fileUrl) 
	{
		SAXReader saxReader = new SAXReader();
		try
		{
			Document document = saxReader.read(new File(fileUrl));//读取XML文件
			Element root = document.getRootElement();//得到根节点
			
			ElementNode elementNode = new ElementNode();
			
			elementNode.setElement(root);
			elementNode.setId("0");
			elementNode.setParentId("");
			
			elementNodes.add(elementNode);//把根节点加入到容器中去。
			num++;
			
			for(int i = 0;i < elementNodes.size();i++)
			{
				List<Element> elements = new ArrayList<Element>();
				elements = elementNodes.get(i).getElement().elements();//得到第i个节点的所有子节点
				for(int j = 0;j < elements.size();j++)
				{
					ElementNode node = new ElementNode();
					node.setParentId(String.valueOf(i));
					node.setElement(elements.get(j));
					node.setId(String.valueOf(num));
					elementNodes.add(node);
					num++;
				}
			}
			
		}catch (Exception e) 
		{
			e.printStackTrace();
		}
	}
	public static String createXmlDoc(String fileUrl) 
	{
		Document document = DocumentHelper.createDocument();
		document.setXMLEncoding("UTF-8");
		try
		{
			Element root = document.addElement("root") ;//创建根节点
			System.out.println("即将生成新的文件");
			elementNodes.get(0).setElement(root);
			int i = 0;
			int childNums = 0;
			while(i < elementNodes.size())
			{
				childNums = elementNodes.size();
				for(int j = i+1; j < childNums; j++)
				{
					if(elementNodes.get(i).getId().equals(elementNodes.get(j).getParentId()))
					{
						List<Attribute> attributes = new ArrayList<Attribute>();
						attributes = elementNodes.get(j).getElement().attributes();
						Element element = elementNodes.get(i).getElement().addElement(elementNodes.get(j).getElement().getName());
						element.setText(elementNodes.get(j).getElement().getText());
						element.setAttributes(attributes);
						elementNodes.get(j).setElement(element);
					}
				}
				i++;
			}
			try
			{
				OutputFormat format = OutputFormat.createPrettyPrint();
				XMLWriter output = new XMLWriter(new FileOutputStream( new File(fileUrl) ), format);
			    output.write( document );
			    output.close();
			    System.out.println("文件已经生成,"+fileUrl);
			}
			catch(IOException e)
			{
				System.out.println(e.getMessage());
			}
		}
		catch (Exception e) {
			e.printStackTrace();
		}
		finally
		{
			return fileUrl;
		}
	}
}

 

5、结果:

<?xml version="1.0" encoding="UTF-8"?>
<root>
  <users>
    <user name="ddd" mail="renyi@renyi.com" age="20"/>
    <user name="ddd" mail="renyi@renyi.com" age="20"/>
    <user name="ddd" mail="renyi@renyi.com" age="20"/>
    <user name="ddd" mail="renyi@renyi.com" age="20"/>
    <user name="ddd" mail="renyi@renyi.com" age="20"/>
  </users>
</root>

 

分享到:
评论

相关推荐

    Dom4j 解析Xml文档及 XPath查询 学习笔记

    **标题:** Dom4j 解析Xml文档及 XPath查询 学习笔记 **正文:** XML(eXtensible Markup Language)是一种标记语言,常用于数据交换、配置存储以及文档结构化表示。在Java世界中,解析XML文档有多种库,其中Dom4j是...

    dom4j解析XML(学习笔记)

    ### DOM4j解析XML知识点详解 #### 一、DOM4j简介 DOM4j是一个用于处理XML文档的Java库,其名称来源于“Document Object Model for Java”,但它与标准的DOM API并不完全相同,而是提供了更为简便和高效的方式来...

    Dom4j学习教程+API+xml实用大全+xml学习笔记+htc

    标题"Dom4j学习教程+API+xml实用大全+xml学习笔记+htc"提及了几个关键主题,包括Dom4j的学习资源、API文档,以及关于XML的实用指南和学习笔记,还提到了一个名为"htc"的文件,可能是关于HTC设备或技术的文档。...

    XML DOM4J学习笔记

    本篇笔记将深入探讨XML DOM4J的学习要点。 一、XML基础知识 1. XML结构:XML文档由元素(Element)、属性(Attribute)、文本内容(Text)、注释(Comment)等组成。每个XML文档都有一个根元素,其他元素嵌套在根...

    DOM4J笔记.学习如何应用DOM4J开发XML

    DOM4J使用SAXReader类来解析XML文档。在示例代码中,第14行创建了一个SAXReader实例,然后在第15行通过`read(URL url)`方法读取指定URL的XML文件并将其转换为Document对象。这种方法允许快速、有效地处理大型XML...

    Dom4j学习笔记

    **标题解析:** "Dom4j学习笔记" 这个标题明确指出了我们要探讨的主题——Dom4j。Dom4j是一个流行的Java库,用于处理XML文档。它提供了丰富的API,使得XML的读取、写入、操作变得简单易行。在学习笔记中,通常会涵盖...

    dom4j 学习笔记

    **DOM4J学习笔记** DOM4J是一个强大的Java XML API,它提供了丰富的XML处理功能,包括文档构建、解析、修改和查询。作为一个开源项目,DOM4J在XML处理领域具有广泛的用户基础,因其简单易用和高效性能而备受青睐。...

    dom4j学习笔记

    **DOM4J学习笔记** DOM4J是一个Java库,它提供了强大的XML处理功能,包括解析、操作和生成XML文档。这个库是开源的,广泛应用于Java应用程序中,特别是在需要处理XML数据时。DOM4J的设计目标是易于使用,同时保持高...

    DOM4J学习笔记

    DOM4J的学习笔记主要涵盖以下几个核心知识点: 1. **DOM4J概述**: DOM4J是一个开源项目,其设计目标是提供一个简单且功能丰富的XML API,它既支持SAX和DOM,又引入了面向对象的设计,使得XML处理更加方便。DOM4J...

    dom4j学习笔记.txt

    ### DOM4J学习笔记 #### 一、DOM4J简介 DOM4J是一个Java库,用于处理XML数据。它提供了一种非常灵活的方式来解析、创建和修改XML文档。DOM4J是一个开源项目,由Red Hat公司支持。相较于其他XML解析器如DOM、SAX等...

    dom4j 包含例子 各种增删改查

    "2012-4-10 有关 xml dom4j的 crud"可能是另一个教程或者笔记,详细讲解了如何利用DOM4J进行XML的CRUD操作。这个文件可能包含了详细的步骤和代码示例,对于学习DOM4J非常有帮助。 "自己写的 dom4j的例子"很显然是...

    java与xml 学习笔记整理

    XML文档对象模型(DOM)是一种广泛使用的解析XML的方式。DOM允许开发者通过Java代码与XML文档的结构进行交互,就像一棵树,每个元素、属性和文本都是树上的节点。 在Java中,DOM解析通常涉及以下步骤: 1. **创建...

    xml学习笔记

    3. **DOM4J解析XML**:DOM4J使用Document对象来表示整个XML文档,Element代表XML的元素,Attribute代表元素的属性。通过`DocumentBuilderFactory`和`DocumentBuilder`可以构建XML文档的DOM树,然后通过遍历DOM树来...

    详细的XML解析笔记

    本文档详细的给出了XML的介绍和XML解析的实例。包括DOM4J和SAX解析,节点的名和值得读取,属性的读取。生成XML文件等

    PHPXML学习笔记

    使用SimpleXML库解析XML文件: ```php $xml = simplexml_load_file('example.xml'); foreach ($xml-&gt;children() as $child) { echo 'Name: ' . $child-&gt;getName() . ', Value: ' . (string)$child . PHP_EOL; } ```...

    解析XML文件例子

    以下是一些关于解析XML文件的知识点: 1. XML结构: - 根元素:XML文档必须有一个根元素,所有其他元素都包含在这个根元素内。 - 元素:XML中的基本单位,用尖括号 `&lt; &gt;` 包围,如 `&lt;book&gt;`。 - 属性:元素可以...

    Xml学习笔记.pdf

    由于提供的文件信息中包含了大量的XML学习资料,且内容比较丰富,我们将逐一详细解释这些内容所涵盖的知识点。 **XML简介** XML是Extensible Markup Language(可扩展标记语言)的缩写,它是一种用于标记电子文件...

    pugixml学习笔记1 加载文件

    在“pugixml学习笔记1 加载文件”中,我们将探讨如何利用pugixml库来加载XML文件,包括从内存、文件、字符串和流中加载。 首先,我们需要了解pugixml的核心类:`pugi::xml_document`、`pugi::xml_node`和`pugi::xml...

    Xml高级学习笔记

    【XML 高级学习笔记】 XML(Extensible Markup Language)是一种可扩展标记语言,与HTML类似,但其设计目标是存储和传输数据,而非呈现数据。XML允许用户自定义标签,使得它成为一种自描述的语言,并且是W3C的标准...

Global site tag (gtag.js) - Google Analytics