`
yianpuodiaotu
  • 浏览: 242669 次
  • 性别: Icon_minigender_1
  • 来自: 济南
社区版块
存档分类
最新评论

dom4j操作工具类

阅读更多
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();
    }
  }

分享到:
评论
3 楼 xtcpcgx 2010-08-23  
很好的资料,收藏啦 !!
2 楼 garyh 2009-01-15  
很好,谢谢
1 楼 logcos 2008-08-06  
不错。谢谢~

相关推荐

    dom4j 工具类

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

    dom4j工具类

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

    dom4j 工具类 使用例子

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

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

    在本教程中,我们将深入探讨如何使用DOM4J来解析XML文件,并创建一个无敌连环解析工具类。 首先,我们需要了解XML的基本概念。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时,只需将相应的jar包(如dom4j-1.6.1.jar、dom4j-2.0.2.jar或dom4j-2.1.1.jar)导入到类路径中,即可开始利用其功能处理XML文档。导入后,可以按照DOM4J提供的API进行编程,快速实现XML的读写...

    xml-dom4j解析工具类

    这个“xml-dom4j解析工具类”显然是为了简化XML文档操作而设计的,它利用DOM4J库来处理XML数据。 首先,让我们详细了解一下DOM4J的核心概念。DOM4J提供了一个灵活的API,以树形结构表示XML文档。在DOM(Document ...

    DOM4J xml解析工具

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

    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工具。

    使用Maven管理项目,实现DOM4j操作XML文件

    DOM4j则是一个强大的Java库,用于处理XML文档,提供了丰富的API来实现XML的读取、写入、修改等操作。在这个示例中,我们将深入探讨如何利用Maven管理和DOM4j来操作XML文件。 首先,让我们了解一下Maven。Maven是...

    dom4j 和xpath

    DOM4J和XPath是XML处理的得力工具,DOM4J为XML文档提供了一种直观且高效的处理方式,而XPath则提供了强大的查询语言,两者结合可以更便捷地进行XML数据的处理和分析。在Java项目中,使用DOM4J配合XPath可以极大地...

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

    - 解析后得到`Document`对象,可以使用DOM4J的API进行操作,如`selectNodes()`, `element()`, `text()`等。 - DOM4J还支持XPath表达式,可以通过`XPathFactory`和`XPath`对象来选择XML节点。 在实际应用中,DOM4J...

    dom4j-2.1.3.zip

    在"dom4j-2.1.3.jar"文件中,包含了DOM4J库的所有类和方法,可以用于构建、解析和操作XML文档。这个版本的DOM4J在前一版本的基础上进行了优化和更新,以适应不断发展的Java技术和XML应用场景。 "dom4j-2.1.3-...

    dom4j.jar 下载

    4. **使用**:在你的代码中导入DOM4J的类,如`org.dom4j.Document`、`org.dom4j.Element`等,然后使用提供的API进行XML操作。 DOM4J的核心功能包括: - **解析XML**:DOM4J支持SAX和DOM解析方式,可以根据需求选择...

    dom4j-2.0.3.zip

    总结,DOM4J作为Java处理XML的首选工具之一,其易用性、灵活性和高效性为XML操作带来了极大的便利。了解并掌握DOM4J,对于提升XML相关项目的开发效率至关重要。通过阅读DOM4J的API文档(如`dom4j-2.0.3-javadoc.jar`...

    dom4j所依赖的所有jar包

    综上所述,DOM4J 1.6.1版本是处理XML文档的强大工具,其高效的API和对XPath的良好支持使得XML操作变得简单易行。在Java项目中,尤其是需要频繁处理XML结构数据时,DOM4J是一个不可或缺的库。通过结合`dom4j-1.6.1....

    dom4j操作xml

    - 使用`DocumentBuilderFactory`和`DocumentBuilder`类可以将XML字符串转换为`Document`对象,这是DOM4J的核心对象。 - `Document`对象代表整个XML文档,而`Element`对象则代表XML中的标签。 - 例如:`Document ...

    org.dom4j.jar

    总的来说,DOM4J是Java开发中处理XML不可或缺的工具,它提供了丰富的功能和良好的性能,使得XML操作变得简单而高效。当遇到“ClassNotFoundException: org.dom4j.DocumentException”这样的错误时,只需确保DOM4J库...

Global site tag (gtag.js) - Google Analytics