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

Dom4J工具类

    博客分类:
  • java
阅读更多
import java.io.File;
import java.io.FileOutputStream;
import java.io.FileWriter;
import java.io.IOException;
import java.io.OutputStreamWriter;
import java.io.StringReader;
import java.util.List;

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

public class FlowConfigHandle {

	String path = ""; //$NON-NLS-1$

	File file;

	SAXReader saxReader = new SAXReader();

	Document document = null;
	org.dom4j.io.OutputFormat format = new org.dom4j.io.OutputFormat()
			.createPrettyPrint();

	public FlowConfigHandle(Document document) {
		this.document = document;
		path = document.getPath();
	}

	public FlowConfigHandle(String path) {
		try {
			// saxReader.setEncoding("UTF-8");
			this.path = path;
			file = new File(path);
			document = saxReader.read(file);
		} catch (DocumentException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}

	/**
	 * @param key
	 * @param isAttribute
	 * @return
	 */
	public String get(String key, Boolean isAttribute) {
		try {
			List list = document.selectNodes(key);
			if (list != null && list.size() > 0) {
				if (isAttribute) {
					return ((Attribute) list.iterator().next()).getText();
				} else {
					return ((Element) list.iterator().next()).getText();
				}
			}
		} catch (Exception e) {
			e.printStackTrace();
		}
		return ""; //$NON-NLS-1$
	}

	public List getList(String key, Boolean isAttribute) {
		try {
			if (!isAttribute) {
				List list = document.selectNodes(key);
				return list;
			} else {
				return null;
			}
		} catch (Exception e) {
			e.printStackTrace();
		}
		return null;
	}

	/**
	 * @param key
	 * @param value
	 * @throws IOException
	 */

	public void set(String key, String value, Boolean isAttribute) {
		try {
			if (isAttribute) {
				List list = document.selectNodes(key);
				((Attribute) list.iterator().next()).setValue(value);
			} else {
				List list = document.selectNodes(key);
				((Element) list.iterator().next()).setText(value);
			}
		} catch (Exception e) {
			e.printStackTrace();
		}
	}

	/**
	 * @param key
	 * @param value
	 * @throws IOException
	 */
	public void delete(String key, String value, Boolean isAttribute) {
		try {
			List list = document.selectNodes(key);
			Element element = (Element) list.iterator().next();
			if (isAttribute) {
				List attributeList = document.selectNodes(key + "/@" + value); //$NON-NLS-1$
				Attribute attribute = (Attribute) attributeList.iterator()
						.next();
				element.remove(attribute);
			} else {
				List childList = document.selectNodes(key + "/" + value); //$NON-NLS-1$
				Element childElement = (Element) childList.iterator().next();
				element.remove(childElement);
			}
		} catch (Exception e) {
			e.printStackTrace();
		}
	}

	/**
	 * @param key
	 * @param stringArray
	 * @param isAttribute
	 * @throws IOException
	 */

	public Element insert(String key, String[] stringArray, Boolean isAttribute) {
		Element element = null;
		try {
			List list = document.selectNodes(key);
			element = (Element) list.iterator().next();
			if (isAttribute) {
				element = element.addAttribute(stringArray[0], stringArray[1]);
			} else {
				element = element.addElement(stringArray[0]);
				element.setText(stringArray[1]);
			}
		} catch (Exception e) {
			e.printStackTrace();
		}

		return element;
	}

	/**
	 * 
	 * @param document
	 * @throws IOException
	 */
	public void save(Document document) throws IOException {
		try {

			format.setEncoding("utf-8"); //$NON-NLS-1$
			XMLWriter writer = new XMLWriter(new FileWriter(new File(path)),
					format);
			writer.write(document);
			writer.close();
		} catch (Exception e) {
			e.getStackTrace();
		}
	}

	// public void doSave() throws IOException{
	// try{
	// document = saxReader.read(file);
	// java.io.Writer wr=new java.io.OutputStreamWriter(new
	// java.io.FileOutputStream(file),"UTF-8");
	// document.write(wr);
	// }catch (Exception e){
	// e.getStackTrace();
	// }
	//		 
	// }
	public void doSave(){
		writeXML(path, document, "UTF-8"); //$NON-NLS-1$
		// try {
		// format.setEncoding("utf-8");
		// document.setXMLEncoding("UTF-8");
		// OutputStreamWriter osw = new OutputStreamWriter(new
		// FileOutputStream(file),"UTF-8");
		// XMLWriter writer = new XMLWriter(osw, format);
		// writer.write(document);
		// writer.close();
		// } catch (Exception e) {
		// e.getStackTrace();
		// }
	}

	/**
	 * @param document
	 * @return
	 */
	public Element getRootElement(Document document) {
		return 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....
			}
		}
	}

	public String getStringFromDocument() {
		String text = document.asXML();
		return text;
	}

	public Document getDocument() {
		return document;
	}

	public void setDocument(Document document) {
		this.document = document;
	}

	public void writeXML(String file, Document document, String encoding) {
		try {
			document.setXMLEncoding("UTF-8"); //$NON-NLS-1$
			OutputStreamWriter outWriter = new OutputStreamWriter(
					new FileOutputStream(file), "UTF-8"); //$NON-NLS-1$
			OutputFormat format = OutputFormat.createPrettyPrint();
			format.setEncoding(encoding == null ? format.getEncoding()
					: encoding);
			XMLWriter writer = new XMLWriter(outWriter, format);
			writer.write(document);
			writer.close();
		} catch (IOException ex) {
			ex.printStackTrace();
		}
	}

	public void setDocument(String xml) {
		try {
			StringReader in  = new StringReader(xml);
			document = saxReader.read(in);
//			System.out.println(document.asXML());
		} catch (DocumentException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}
}

 

 


一.Document对象相关

1.读取XML文件,获得document对象.

SAXReader reader = new SAXReader();
            Document  document = reader.read(new File("input.xml"));
 

2.解析XML形式的文本,得到document对象.

            String text = "<members></members>";
            Document document = DocumentHelper.parseText(text);
 


3.主动创建document对象.

            Document document = DocumentHelper.createDocument();
            Element root = document.addElement("members");// 创建根节点
 


二.节点相关

1.获取文档的根节点.

Element rootElm = document.getRootElement();
 


2.取得某节点的单个子节点.

Element memberElm=root.element("member");// "member"是节点名

 

3.取得节点的文字

String text=memberElm.getText();

 

也可以用:

String text=root.elementText("name");
 


这个是取得根节点下的name字节点的文字.

4.取得某节点下名为"member"的所有字节点并进行遍历.

List nodes = rootElm.elements("member");

for (Iterator it = nodes.iterator(); it.hasNext();) {
   Element elm = (Element) it.next();
   // do something
}

 

5.对某节点下的所有子节点进行遍历.

            for(Iterator it=root.elementIterator();it.hasNext();){
                Element element = (Element) it.next();
                // do something
            }
 

6.在某节点下添加子节点.

Element ageElm = newMemberElm.addElement("age");

 

7.设置节点文字.

ageElm.setText("29");

 

8.删除某节点.

parentElm.remove(childElm);// childElm是待删除的节点,parentElm是其父节点
 


三.属性相关.
1.取得某节点下的某属性

            Element root=document.getRootElement();   
            Attribute attribute=root.attribute("size");// 属性名name

 

2.取得属性的文字

            String text=attribute.getText();
 

也可以用:

String text2=root.element("name").attributeValue("firstname");
 

这个是取得根节点下name字节点的属性firstname的值.

3.遍历某节点的所有属性

            Element root=document.getRootElement();   
            for(Iterator it=root.attributeIterator();it.hasNext();){
                Attribute attribute = (Attribute) it.next();
                String text=attribute.getText();
                System.out.println(text);
            }
 


4.设置某节点的属性和文字.

newMemberElm.addAttribute("name", "sitinspring");

 

5.设置属性的文字

            Attribute attribute=root.attribute("name");
            attribute.setText("sitinspring");
 

6.删除某属性

            Attribute attribute=root.attribute("size");// 属性名name
            root.remove(attribute);
 

四.将文档写入XML文件.
1.文档中全为英文,不设置编码,直接写入的形式.

XMLWriter writer = new XMLWriter(new FileWriter("output.xml"));
writer.write(document);
writer.close();
 

2.文档中含有中文,设置编码格式写入的形式.

            OutputFormat format = OutputFormat.createPrettyPrint();
            format.setEncoding("GBK");    // 指定XML编码       
            XMLWriter writer = new XMLWriter(new FileWriter("output.xml"),format);
           
            writer.write(document);
            writer.close();
 

五.字符串与XML的转换
1.将字符串转化为XML

String text = "<members> <member>sitinspring</member> </members>";
Document document = DocumentHelper.parseText(text);
 

2.将文档或节点的XML转化为字符串.

            SAXReader reader = new SAXReader();
            Document  document = reader.read(new File("input.xml"));           
            Element root=document.getRootElement();               
            String docXmlText=document.asXML();
            String rootXmlText=root.asXML();
            Element memberElm=root.element("member");
            String memberXmlText=memberElm.asXML();

 

六.使用XPath快速找到节点.
读取的XML文档示例

<?xml version="1.0" encoding="UTF-8"?>
<projectDescription>
  <name>MemberManagement</name>
  <comment></comment>
  <projects>
    <project>PRJ1</project>
    <project>PRJ2</project>
    <project>PRJ3</project>
    <project>PRJ4</project>
  </projects>
  <buildSpec>
    <buildCommand>
      <name>org.eclipse.jdt.core.javabuilder</name>
      <arguments>
      </arguments>
    </buildCommand>
  </buildSpec>
  <natures>
    <nature>org.eclipse.jdt.core.javanature</nature>
  </natures>
</projectDescription>
 


使用XPath快速找到节点project.

 public static void main(String[] args){
    SAXReader reader = new SAXReader();
   
    try{
      Document  doc = reader.read(new File("sample.xml"));
     
      List projects=doc.selectNodes("/projectDescription/projects/project");
     
      Iterator it=projects.iterator();
     
      while(it.hasNext()){
        Element elm=(Element)it.next();      
        System.out.println(elm.getText());
      }
     
    }
    catch(Exception ex){
       ex.printStackTrace();
    }
  }
 
分享到:
评论

相关推荐

    dom4j工具类

    **DOM4J工具类详解** DOM4J是一个强大的Java XML处理库,它提供了一套灵活且功能丰富的API,使得在Java应用程序中解析、创建、修改XML文档变得异常简单。DOM4J的名字来源于“DOM for Java”,它是一个基于DOM模型的...

    dom4j 工具类

    **DOM4J工具类详解** DOM4J是一个强大的Java XML API,它提供了全面的XML处理功能,包括解析、操作和生成XML文档。DOM4J在Java社区中被广泛使用,因其简洁的API和高效的性能而受到青睐。在这个文档中,我们将深入...

    Dom4j工具类

    主要方法: /** * 使用条件:在发放外部建立一个静态Map, String&gt; * 此方法得到一个map,map中的key为节点的名字,value为节点的值 * 如果会用到多个值,可使用此方法获得一个map,然后根据键值对取值,会使...

    dom4j 工具类 使用例子

    在这个"dom4j工具类使用例子"中,我们将深入探讨如何利用DOM4J进行XML处理。 首先,`Dom4jUtil.java`可能是包含DOM4J实用方法的类。这个类可能包括了创建、查询、修改XML文档的各种静态方法。例如,可能会有用于...

    java Dom4j 无敌连环解析XML工具类

    在本教程中,我们将深入探讨如何使用DOM4J来解析XML文件,并创建一个无敌连环解析工具类。 首先,我们需要了解XML的基本概念。XML(可扩展标记语言)是一种标记语言,常用于数据交换和存储。它的结构化特性使其非常...

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

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

    所有版本的dom4j工具包

    标题提到的"所有版本的dom4j工具包"表明这是一个包含多版本DOM4J库的集合,可能包括了从早期到较新的一些版本,如dom4j-1.4.jar、dom4j-1.6.1.jar和dom4j-1.5.2.jar。这些不同版本的库可能分别对应于不同的功能特性...

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

    总之,DOM4J作为一款强大的XML处理工具,为Java开发者提供了丰富的功能和良好的性能,是处理XML文档的理想选择。无论是小型项目还是大型企业级应用,都能从中受益。通过持续的版本更新和社区支持,DOM4J保持着其在...

    Dom4jUtils 工具类让你更加方便操作XML的MarkerIce.Jar

    本文将深入探讨`Dom4jUtils`工具类如何增强DOM4J的功能,以及在`MarkerIce.jar`中它如何帮助开发者更便捷地处理XML。 首先,`Dom4jUtils`工具类通常包含了对DOM4J库的一系列实用方法,旨在简化XML的读取、解析、...

    dom4j dom4j dom4j dom4j

    DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了灵活且高效的API,使得XML的...不过对于大多数常规XML处理任务,DOM4J已经足够胜任,并且由于其易用性和广泛的支持,DOM4J成为了许多Java开发者首选的XML工具。

    dom4j-2.1.3.zip

    总结来说,DOM4J 2.1.3是一个强大且易用的XML处理工具,它的API文档和源代码为开发者提供了便利的学习和开发环境。无论你是XML初学者还是资深开发者,DOM4J都能成为你处理XML任务的得力助手。通过深入学习和实践,你...

    DOM4J xml解析工具

    DOM4J提供了对命名空间的完整支持,方便处理这类问题。 5. **文档转换**:DOM4J可以将XML文档转换为其他格式,如Java对象、HTML、DOM或SAX事件。 6. **集成其他技术**:DOM4J与许多其他Java库如JAXB(Java API for...

    dom4j-2.0.3.zip

    1. **Element**: DOM4J中的Element类代表XML文档中的元素节点,它是DOM4J中最重要的类。通过Element,我们可以获取或设置元素的属性,添加子元素,以及遍历元素的子节点。 2. **Attribute**: 属性是元素的一部分,...

    自己写的一个dom4j解析xml文件工具类

    自己写的一个dom4j解析xml文件工具类

    dom4j所依赖的所有jar包

    2. **文档对象模型**:DOM4J提供了Element、Attribute、Namespace等类,这些类代表了XML文档中的元素、属性和命名空间。它们提供了丰富的API,可以方便地进行添加、删除、查找和修改操作。 3. **XPath支持**:DOM4J...

    dom4j.jar 下载

    DOM4J是一个强大的Java库,...总的来说,DOM4J是Java开发中处理XML文档的强大工具,它的易用性和灵活性使其在各种项目中得到了广泛应用。通过下载并引入dom4j.jar,开发者可以轻松地集成XML处理功能,提高开发效率。

    org.dom4j.jar

    当我们遇到“java.lang.ClassNotFoundException: org.dom4j.DocumentException”的错误提示时,这通常意味着系统中缺少了DOM4j库,只需将“org.dom4j.jar”添加到项目类路径中即可解决此问题。 DOM4J是基于DOM和SAX...

    dom4j需要的包

    综上所述,DOM4J是一个强大且易用的XML处理工具,配合Jaxen库可以实现XPath查询,而提供的学习文档则是掌握这些功能的重要辅助。在实际开发中,熟练掌握DOM4J能极大地提升XML相关任务的开发效率。

Global site tag (gtag.js) - Google Analytics