`

xml文件解析之Dom4j

    博客分类:
  • xml
阅读更多

以下示例比较简单,仅供初学者参考。

示例引用包:dom4j-1.6.1

 

读取xml文件:

import java.io.ByteArrayInputStream;
import java.io.File;   
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.Iterator;

import org.dom4j.Attribute;   
import org.dom4j.Document;
import org.dom4j.DocumentException;   
import org.dom4j.Element;   
import org.dom4j.ProcessingInstruction;   
import org.dom4j.VisitorSupport;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;


public class XmlReaderDom4j {
	
	public static void main(String[] args){
		//readGB2312();
		readUTF8();
	}
	
	public static void readGB2312(){
		SAXReader reader = new SAXReader();
        File file = new File("src/students.xml");
        
        try {
            Document doc = reader.read(file);
            doc.accept(new MyVistor());
            
        } catch (DocumentException e) {
            e.printStackTrace();
        }
	}
	
	
	public static void readUTF8(){
		try{			
	        SAXReader reader = new SAXReader();
	        OutputFormat format = OutputFormat.createPrettyPrint();
	        format.setEncoding("UTF-8"); //设置XML文件的编码格式

	     File file = new File("src/author.xml");
	        if(file.exists()){
	        	Document document = reader.read(file); //  读取XML文件 
	        	Element root = document.getRootElement(); //  得到根节点
	        	
	        	for(Iterator i = root.elementIterator(); i.hasNext();){
	        		Element e = (Element) i.next();
	                System.out.println(e.getName());
	                System.out.println(e.getPath());
	                System.out.println(e.getText());
	                System.out.println(e.getStringValue());
	                
	                for(Iterator j = e.attributeIterator();j.hasNext();){
	                	Attribute attribute = (Attribute) j.next();
	                	System.out.println(attribute.getStringValue());
	                }
	             }   
	        }else{
	        	System.out.println("文件没找到");
	        }

		}catch(Exception e){
			e.printStackTrace();
		}
	}
	
	
	/**  
	 * 获取Dom4j的Document对象  
	  * @param data  
	 * @param charset  
	 * @return  
	 */  
	public static Document getDocument(String data, String charset) {	       
	    SAXReader reader = new SAXReader();
	    Document document = null;
	    InputStreamReader utfreader = null;
	    InputStream in = null;
	       
	    try {   
	        in = new ByteArrayInputStream(data.getBytes());
	        utfreader = new InputStreamReader(in, charset);
	        document = reader.read(utfreader);
	        
	    }catch (Exception e) {
	    	e.printStackTrace();
	    	
	    }finally {   
	        try {   
	            in.close();   
	        }   
	        catch (IOException e) {
	        	e.printStackTrace();
	        }
	    }
	    
	    return document;     
	}
	
	
	/**
	 * 内部类
	 * @author Administrator
	 *
	 */
	public static class MyVistor extends VisitorSupport {
        public void visit(Attribute node) {
            System.out.println("** Attibute:" + node.getName() + "="  
                    + node.getValue());
        }
  
        public void visit(Element node) {
            if (node.isTextOnly()) {
            	System.out.println("** Element:" + node.getName() + "="  
                        + node.getText());   
            }else{
                System.out.println("--------" + node.getName() + "-------");   
            }
        }   
  
        @Override  
        public void visit(ProcessingInstruction node) {
            System.out.println("** PI:"+node.getTarget()+" "+node.getText());   
        }   
    }
}

 

 author.xml

<?xml version="1.0" encoding="UTF-8"?>
<root>
<author name="詹姆斯" location="UK">小皇帝</author>
<author name="科比" location="US">Bob McWrirter</author>
</root>

 

 

 生成XML文件:

import java.io.FileWriter;   
import java.io.IOException;   
  
import org.dom4j.Document;   
import org.dom4j.DocumentHelper;   
import org.dom4j.Element;   
import org.dom4j.io.OutputFormat;   
import org.dom4j.io.XMLWriter;


public class XmlWriterDom4j {
	
    public static void main(String[] args) {   
        try {
            XMLWriter writer = new XMLWriter(new FileWriter("src/author.xml"));   
            Document doc = createDoc();
            writer.write(doc);
            writer.close();   
  
            // Pretty print the document to System.out   
            // 設置了打印的格式,将读出到控制台的格式进行美化
            OutputFormat format = OutputFormat.createPrettyPrint();   
            writer = new XMLWriter(System.out, format);
            writer.write(doc);
  
        } catch (IOException e) {   
             e.printStackTrace();
        }   
    }
	
    public static Document createDoc() {
        Document doc = DocumentHelper.createDocument();
        Element root = doc.addElement("root");
        Element author1 = root.addElement("author")
        		.addAttribute("name","James")
        		.addAttribute("location", "UK")
                .addText("Jame Strachan");
        
        Element author2 = root.addElement("author")
        		.addAttribute("name", "Bob")
                .addAttribute("location", "US")
                .addText("Bob McWrirter");
        
        return doc;
    }

}

 

 

0
0
分享到:
评论

相关推荐

    Dom4j解析XML文档.doc

    无论是读取XML文件,解析XML字符串,还是创建、修改和遍历XML结构,DOM4J都提供了简洁的接口,极大地简化了开发者的工作。在实际的开发中,掌握DOM4J的使用,能够帮助你更有效地处理XML数据,提高代码的可维护性和...

    dom4j解析xml详解

    DOM4J的核心优势之一在于其丰富的接口体系,这些接口定义在`org.dom4j`包内,提供了对XML文档进行读写、查询、修改等操作的能力。 1. **Attribute**: 代表XML中的属性,可用于获取和设置属性值。 2. **Branch**: ...

    XML解析技术DOM4J解析

    rootEle.addComment("这是一个dom4j生成的xml文件"); Element empEle = rootEle.addElement("emp"); empEle.addAttribute("id", "1"); Element nameEle = empEle.addElement("name"); nameEle.setText(...

    DOM4J jar包 xml解析 所有的dom4j-1.6.1 dom4j-2.0.2 dom4j-2.1.1包 导入直接使用

    6. **StAX(Streaming API for XML)支持**:DOM4J也支持StAX解析器,这种解析方式结合了SAX的高效和DOM的易用性,可以在处理大型XML文件时节省内存。 7. **与JAXB集成**:DOM4J可以与Java Architecture for XML ...

    dom4j 解析(读取) xml 节点数据

    要开始解析XML文件,首先需要导入DOM4J的相关包: ```java import org.dom4j.Document; import org.dom4j.DocumentException; import org.dom4j.Element; import org.dom4j.io.SAXReader; ``` 接下来,我们将创建...

    dom4j解析xml文件的压缩包

    5. **事件驱动解析(SAX)**:除了传统的DOM解析外,DOM4J还支持SAX解析器,这种解析方式适用于处理大型XML文件,因为它不需要一次性加载整个文档到内存。 6. **Namespace支持**:DOM4J提供了对XML命名空间的全面...

    java解析XML dom4j dom4j-1.6.1.jar

    Java解析XML时,dom4j是一个非常流行的库,它提供了灵活且强大的API来处理XML文档。dom4j-1.6.1.jar是这个库的一个版本,发布于2005年,它支持XML的读取、写入、操作以及查询功能。在本文中,我们将深入探讨dom4j的...

    xmldom4j解析

    在“jar包执行20190331.rar”文件中,可能包含了一个Java项目,该项目使用DOM4J库解析XML文件并执行相关业务逻辑。执行此类项目通常涉及以下步骤: 1. 将jar包解压,找到主类(包含main方法)。 2. 使用Java命令行...

    dom4j---xml解析jar包

    在Java环境中,解析XML文档时,我们通常会遇到各种库,其中DOM4J是一个非常流行的、功能强大的开放源代码库。这个库不仅简化了XML处理,还提供了XPath和XSLT的支持,使其成为Java开发者处理XML的首选工具之一。 **...

    XML的四种解析器(dom,sax,jdom,dom4j)原理及性能比较,超详细

    SAX 解析器将 XML 文档解析为一系列事件,每当发现特定的标签时,触发一个回调方法。SAX 解析器的优点是: * 能够立即开始解析,不需要等待所有数据被处理 * 不需要将数据存储在内存中,适合大型文档 * 选择性地...

    dom4j 解析写入xml

    1、xml文档解析 2、 dom4j解析xml 3、实现xml文件解析 xml字符串解析 xml MAP键值对解析 4、实现xml写入与生成文件

    dom4j.jar包,java解析xml dom4j.jar包

    解析XML文件时,DOM4J提供了两种主要的方式:DOM阅读器和SAX阅读器。 - **DOM阅读器**:首先,通过`DocumentFactory.createDocument()`方法创建一个`Document`对象,然后使用`read()`方法读取XML文件,将整个XML...

    Java解析xml配置文件,DOM4J解析xml配置文件,提供使用文档和源码下载

    使用DOM4J,可以这样加载XML文件: ```java DocumentFactory documentFactory = DocumentFactory.getInstance(); File xmlFile = new File("path_to_your_xml_file.xml"); Document document = documentFactory....

    Dom4j解析配置文件与xml小例子

    Dom4j是一个非常流行的Java库,用于处理XML文档。它提供了灵活且功能强大的API,使得XML的解析、创建、修改变得简单易行。本篇将通过一个实际的例子来探讨如何使用Dom4j解析XML配置文件。 首先,我们需要了解DOM4J...

    xml 三种解析方式dom,sax,dom4j

    为了处理XML文档,有三种主要的解析方式:DOM、SAX和DOM4J。每种方法都有其特点和适用场景,下面将详细介绍这三种解析方式。 1. DOM(Document Object Model) DOM解析器将整个XML文档加载到内存中,构建一个树形...

    dom4j读写xml文档实例

    要使用DOM4J读取XML文档,首先需要创建一个`SAXReader`对象,然后调用`read`方法传入XML文件路径。这将返回一个`Document`对象,我们可以从中获取所有元素信息。 ```java File file = new File("path_to_xml_file")...

    dom,dom4j,sax 解析xml文件实例

    本文将深入探讨DOM、DOM4J和SAX三种常用的XML解析方法,并结合具体的实例进行详细讲解。 首先,DOM(Document Object Model)是W3C组织推荐的一种XML解析标准。它将整个XML文档加载到内存中,构建一个树形结构,...

    使用dom4j 和本地dom 解析xml 文件

    在Java中,解析XML文件是常见的任务,通常有DOM(Document Object Model)和DOM4J两种方式。下面我们将详细探讨这两种解析方法。 DOM解析方式是将整个XML文件加载到内存中,形成一棵DOM树,每个节点代表XML文档的一...

    XML文件解析的_DOM4J-最新jar

    这个“XML文件解析的_DOM4J-最新jar”是一个包含DOM4J库的最新版本的Java档案(JAR)文件,用于在Java项目中处理XML。 DOM4J的主要功能包括: 1. **XML解析**:DOM4J支持多种解析方式,如DOM、SAX和StAX。其中,...

Global site tag (gtag.js) - Google Analytics