- 浏览: 253026 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
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 2296L-Larry_Lau@163.com#24777-1i8 ... -
JVM介绍
2012-03-23 09:52 1020JVM 一、什么是Java虚拟机 当你谈到Jav ... -
Velocity语法
2012-03-22 18:20 1197一、基本语法 1、& ... -
Java排列组合算法
2012-03-11 23:07 3834import java.util.ArrayList; ... -
UrlRewrite使用小结(转)
2011-09-01 10:37 1334urlrewrite顾名思义,就是 ... -
JAVA检测字符串编码并转换
2011-08-03 14:15 5890就一个类,detectUtf8(String w3UrlPar ... -
JAVA NIO 简介
2011-03-09 13:20 909http://www.iteye.com/topic/8344 ... -
解读NIO Socket非阻塞模式
2011-03-09 11:58 1327前言: jdk供的无阻塞I/O(NIO)有效解决了多 ... -
一台机器运行多个JBoss多实例
2011-02-28 10:12 7612我们经常会遇到这种情况,有时候希望在同一台机器上部署若干个JB ... -
如何使 maven+jetty运行时不锁定文件
2011-02-23 13:07 2652原因是Jetty会使用内存映射文件来缓存静态文件,其中包括js ... -
java压缩文件夹下的所有文件和选定文件及乱码解决
2010-12-27 15:04 2260在linux下,如果文件夹内的文件是中文名,那么压缩后,这些文 ... -
Json-lib在Json转Java时日期为空处理出错的解决办法
2010-12-07 20:03 12117我在处理json和java的相互转换中出现这样 ... -
二进制、八进制、十进制、十六进制
2010-11-06 12:57 1797一、 十进制与二进 ... -
WebService开发经验(转载)
2010-11-05 08:52 1924去年,在一个大型项目(1500w)中用到Web Servi ... -
根据sessionId获取Session对象
2010-10-22 15:51 7617Servlet2.1之后不支持SessionContext里面 ... -
Spring事务配置的五种方式
2010-09-02 17:20 840Spring配置文件中关于事务配置总是由三个组成部分, ... -
java webservice的发布以及调用
2010-08-25 13:13 6012安装axis 下载:http://ws.apache.org/ ... -
利用Spring的AOP来配置和管理你的二级缓存(EHCache)
2010-08-03 16:23 928如果我们的项目中采用的是Spring+hibernate来构 ... -
Java操作XML文件 dom4j 篇
2010-07-30 16:44 1014在项目中,我们很多都用到了xml文件,无论是参数配置还是与其它 ... -
dom4j建立,修改XML文档,并解决格式化输出和中文
2010-07-30 16:40 1178package com.holen.dom4j; imp ...
相关推荐
dom4(for)j(java) 是为java解析dom提供的工具类,甚至sum公司有些员工都使用这个工具类解析
封装dom4j 实现了一些实用的操作xml的方法
主要方法: /** * 使用条件:在发放外部建立一个静态Map, String> * 此方法得到一个map,map中的key为节点的名字,value为节点的值 * 如果会用到多个值,可使用此方法获得一个map,然后根据键值对取值,会使...
dom4j 的包装类,可以让你轻易获取并改变xml的节点 以及生成一个xml
java Dom4j 无敌连环解析XML工具类
使用dom4j 和本地dom 解析xml 文件
自己写的一个dom4j解析xml文件工具类
dom4j是sourceforge.net上的一个开源项目,主要用于对XML的解析。
DOM4j 是一个很好的 对xml数据进行解析的工具。。
dom4j 和dom4j 是一款比较好用的Xml解析工具jar,其中部分功能需要xpath的支持
基于dom4j的读写xml文件的工具包。封装了dom4j操作xml文档的常和方法。 支持两种读写方法。1:针对小文件的读取整个文档,2:针对大文件的,逐行读取。读到几百M文件毫无压力。
基于XStream,DOM4J实现xml多种工具类,项目中jar包已齐全 可直接运行。希望对大家有所帮助
这是一个xml工具类,解析jar包用的是dom4j-1.6.1; 主要方法: 1.根据节点名称通过循环遍历获取对应的节点; 2.根据节点名称通过循环遍历获取对应的底层节点集合;
使用Dom4j解析XML文件的jar包.
Dom4j解析和生成XML文档 Dom4j解析和生成XML文档 Dom4j解析和生成XML文档 Dom4j解析和生成XML文档 Dom4j解析和生成XML文档
Dom4j封装与解析,附参考模板,个人实际案例,根据自身情况修改
很全的一个dom4j开发包, dom4j工具类的jar包 和 .chm格式的api 欢迎下载共享!
dom4j是一个Java的XML API,是jdom的升级品,用来读写XML文件的。dom4j是一个十分优秀的JavaXML API,具有性能优异、功能强大和极其易使用的特点,它的性能超过sun公司官方的dom技术,同时它也是一个开放源代码的...