- 浏览: 259284 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
jeans_1312:
...
JAVA检测字符串编码并转换 -
zenzuguo:
为啥我在eclipse tomcat6.0启动时总报错
Ma ...
appfuse2.0.2在eclipse下的开发和使用 -
josewu2009:
楼主我用你的方法在window机器 上 压缩后 ,解压文件时报 ...
java压缩文件夹下的所有文件和选定文件及乱码解决 -
TonyLian:
我觉得2楼提出的,只不过是看起来更漂亮而已,原写法也不会出现B ...
Ibatis动态查询例子(#和$以及iterate等的用法) -
zhaoshg:
谢谢 lemonweirui 的更正,帮我发现了一个bug,谢 ...
Ibatis动态查询例子(#和$以及iterate等的用法)
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(); } }
发表评论
-
JProfiler 7.X注册码
2013-05-09 11:23 2368L-Larry_Lau@163.com#24777-1i8 ... -
JVM介绍
2012-03-23 09:52 1064JVM 一、什么是Java虚拟机 当你谈到Jav ... -
Velocity语法
2012-03-22 18:20 1261一、基本语法 1、& ... -
Java排列组合算法
2012-03-11 23:07 3896import java.util.ArrayList; ... -
UrlRewrite使用小结(转)
2011-09-01 10:37 1381urlrewrite顾名思义,就是 ... -
JAVA检测字符串编码并转换
2011-08-03 14:15 5996就一个类,detectUtf8(String w3UrlPar ... -
JAVA NIO 简介
2011-03-09 13:20 965http://www.iteye.com/topic/8344 ... -
解读NIO Socket非阻塞模式
2011-03-09 11:58 1406前言: jdk供的无阻塞I/O(NIO)有效解决了多 ... -
一台机器运行多个JBoss多实例
2011-02-28 10:12 7653我们经常会遇到这种情况,有时候希望在同一台机器上部署若干个JB ... -
如何使 maven+jetty运行时不锁定文件
2011-02-23 13:07 2687原因是Jetty会使用内存映射文件来缓存静态文件,其中包括js ... -
java压缩文件夹下的所有文件和选定文件及乱码解决
2010-12-27 15:04 2323在linux下,如果文件夹内的文件是中文名,那么压缩后,这些文 ... -
Json-lib在Json转Java时日期为空处理出错的解决办法
2010-12-07 20:03 12155我在处理json和java的相互转换中出现这样 ... -
二进制、八进制、十进制、十六进制
2010-11-06 12:57 1874一、 十进制与二进 ... -
WebService开发经验(转载)
2010-11-05 08:52 1987去年,在一个大型项目(1500w)中用到Web Servi ... -
根据sessionId获取Session对象
2010-10-22 15:51 7660Servlet2.1之后不支持SessionContext里面 ... -
Spring事务配置的五种方式
2010-09-02 17:20 907Spring配置文件中关于事务配置总是由三个组成部分, ... -
java webservice的发布以及调用
2010-08-25 13:13 6073安装axis 下载:http://ws.apache.org/ ... -
利用Spring的AOP来配置和管理你的二级缓存(EHCache)
2010-08-03 16:23 1009如果我们的项目中采用的是Spring+hibernate来构 ... -
Java操作XML文件 dom4j 篇
2010-07-30 16:44 1080在项目中,我们很多都用到了xml文件,无论是参数配置还是与其它 ... -
dom4j建立,修改XML文档,并解决格式化输出和中文
2010-07-30 16:40 1227package com.holen.dom4j; imp ...
相关推荐
**DOM4J工具类详解** DOM4J是一个强大的Java XML处理库,它提供了一套灵活且功能丰富的API,使得在Java应用程序中解析、创建、修改XML文档变得异常简单。DOM4J的名字来源于“DOM for Java”,它是一个基于DOM模型的...
**DOM4J工具类详解** DOM4J是一个强大的Java XML API,它提供了全面的XML处理功能,包括解析、操作和生成XML文档。DOM4J在Java社区中被广泛使用,因其简洁的API和高效的性能而受到青睐。在这个文档中,我们将深入...
主要方法: /** * 使用条件:在发放外部建立一个静态Map, String> * 此方法得到一个map,map中的key为节点的名字,value为节点的值 * 如果会用到多个值,可使用此方法获得一个map,然后根据键值对取值,会使...
在这个"dom4j工具类使用例子"中,我们将深入探讨如何利用DOM4J进行XML处理。 首先,`Dom4jUtil.java`可能是包含DOM4J实用方法的类。这个类可能包括了创建、查询、修改XML文档的各种静态方法。例如,可能会有用于...
在本教程中,我们将深入探讨如何使用DOM4J来解析XML文件,并创建一个无敌连环解析工具类。 首先,我们需要了解XML的基本概念。XML(可扩展标记语言)是一种标记语言,常用于数据交换和存储。它的结构化特性使其非常...
在Java中,解析XML文件是常见的任务,通常有DOM(Document Object Model)和DOM4J两种方式。下面我们将详细探讨这两种解析方法。 DOM解析方式是将整个XML文件加载到内存中,形成一棵DOM树,每个节点代表XML文档的一...
标题提到的"所有版本的dom4j工具包"表明这是一个包含多版本DOM4J库的集合,可能包括了从早期到较新的一些版本,如dom4j-1.4.jar、dom4j-1.6.1.jar和dom4j-1.5.2.jar。这些不同版本的库可能分别对应于不同的功能特性...
总之,DOM4J作为一款强大的XML处理工具,为Java开发者提供了丰富的功能和良好的性能,是处理XML文档的理想选择。无论是小型项目还是大型企业级应用,都能从中受益。通过持续的版本更新和社区支持,DOM4J保持着其在...
本文将深入探讨`Dom4jUtils`工具类如何增强DOM4J的功能,以及在`MarkerIce.jar`中它如何帮助开发者更便捷地处理XML。 首先,`Dom4jUtils`工具类通常包含了对DOM4J库的一系列实用方法,旨在简化XML的读取、解析、...
DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了灵活且高效的API,使得XML的...不过对于大多数常规XML处理任务,DOM4J已经足够胜任,并且由于其易用性和广泛的支持,DOM4J成为了许多Java开发者首选的XML工具。
总结来说,DOM4J 2.1.3是一个强大且易用的XML处理工具,它的API文档和源代码为开发者提供了便利的学习和开发环境。无论你是XML初学者还是资深开发者,DOM4J都能成为你处理XML任务的得力助手。通过深入学习和实践,你...
DOM4J提供了对命名空间的完整支持,方便处理这类问题。 5. **文档转换**:DOM4J可以将XML文档转换为其他格式,如Java对象、HTML、DOM或SAX事件。 6. **集成其他技术**:DOM4J与许多其他Java库如JAXB(Java API for...
DOM4J是一个强大的Java库,...总的来说,DOM4J是Java开发中处理XML文档的强大工具,它的易用性和灵活性使其在各种项目中得到了广泛应用。通过下载并引入dom4j.jar,开发者可以轻松地集成XML处理功能,提高开发效率。
1. **Element**: DOM4J中的Element类代表XML文档中的元素节点,它是DOM4J中最重要的类。通过Element,我们可以获取或设置元素的属性,添加子元素,以及遍历元素的子节点。 2. **Attribute**: 属性是元素的一部分,...
自己写的一个dom4j解析xml文件工具类
2. **文档对象模型**:DOM4J提供了Element、Attribute、Namespace等类,这些类代表了XML文档中的元素、属性和命名空间。它们提供了丰富的API,可以方便地进行添加、删除、查找和修改操作。 3. **XPath支持**:DOM4J...
当我们遇到“java.lang.ClassNotFoundException: org.dom4j.DocumentException”的错误提示时,这通常意味着系统中缺少了DOM4j库,只需将“org.dom4j.jar”添加到项目类路径中即可解决此问题。 DOM4J是基于DOM和SAX...
总的来说,DOM4J是一个强大且全面的XML处理工具,无论是在小型项目还是大型企业级应用中,都能发挥重要作用。从DOM4J1.1到DOM4J1.6.1的更新,开发者可以期待更多的改进和新特性,以更好地满足XML处理的需求。