package com.dom4j;

import java.io.FileWriter;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.util.Iterator;
import java.util.List; import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerConfigurationException;
import javax.xml.transform.TransformerException;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.stream.StreamSource; import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.DocumentResult;
import org.dom4j.io.DocumentSource;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter; public class Test1 {
public static void main(String[] args){
//C:/Users/Administrator.PMIMP83HWNIKWOV/Workspaces/MyEclipse 9/TestWeb/WebRoot/
/**
* 我使用绝对路径就会报错unknown protocol: c,不知道什么原因,现在使用的是相对路径,如果不好使用相对路径,直接使用File文件吧
*/
//String uri="WebRoot/xml/languages.xml";
//Document doc=praseXmlToDocument(uri);
//System.out.println(doc.getRootElement().getName());
//Iteratorasdom(doc);
//navigation(doc);
//treeWalk(doc);
//Document doc=createDocument();
//DocmentToFile(doc,"");
StringToDoc(); } public static Document praseXmlToDocument(String url){
/**
* 解析xml文件成document对象
*/
Document document=null;
try {
SAXReader reader=new SAXReader(); document = reader.read(url);
} catch (DocumentException e) {
e.printStackTrace();
}
return document;
} public static void Iteratorasdom(Document document){
/**
* document获取根元素: .getRootElement()
* Node类型获取所有字节点的迭代器 .elementIterator()
* 获取指定名称的所有子节点的迭代器 .elementIterator(String name)
* 获取所有属性的迭代器 .attributeIterator()
*/
Element root=document.getRootElement();
/*for(Iterator i=root.elementIterator();i.hasNext();){
Element element=(Element) i.next();
System.out.println(element.getName());
for(Iterator it=element.attributeIterator();it.hasNext();){
Attribute att=(Attribute) it.next();
System.out.println(att.getName()+"="+att.getStringValue());
}
}*/
for(Iterator i=root.elementIterator("lan");i.hasNext();){
Element element=(Element) i.next();
for(Iterator it=element.attributeIterator();it.hasNext();){
Attribute att=(Attribute) it.next();
System.out.println(att.getName()+"="+att.getStringValue());
}
}
} public static void navigation(Document document){
/* 使用selectNodes需要使用jaxen.jar
* .selectNodes("//languages/lan/name");获取所有指定名称节点的集合
* .selectSingleNode("//languages/lan/name"); 获取第一个指定名称的节点
* node和document对象都有这个方法
* */
/*List list=document.selectNodes("//languages/lan/name");
for(int i=0;i<list.size();i++){
Node node=(Node) list.get(i);
System.out.println(node.getText());
}*/
Node node=document.selectSingleNode("//languages/lan/name");
System.out.println(node.getText());
} /*遍历document或者element元素的方法*/ public static void treeWalk(Document document) {
treeWalk( document.getRootElement() );
} public static 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
{
System.out.println(node.getText());
}
}
} public static Document createDocument(){
/**
* 添加子元素.addElement(String name)
* 添加属性 .addAttribute(key,value)
* 添加值 .addText(String value)
*/
Document document=DocumentHelper.createDocument();
Element root=document.addElement("root"); Element author1=root.addElement("author")
.addAttribute("name", "James")
.addAttribute("location", "UK")
.addText("James Strachan"); Element author2=root.addElement("author")
.addAttribute("name", "Bob")
.addAttribute("location", "US")
.addText("Bob Mchirter"); return document;
} public static void DocmentToFile(Document doc,String uri){
/* 第一种方法,使用XMLWriter对象的writer方法*/
XMLWriter writer = null;
/*try {
writer=new XMLWriter(new FileWriter(uri));
writer.write(doc);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}*/ /*
* 输出到控制台
* */
OutputFormat format=OutputFormat.createPrettyPrint();
try {
writer=new XMLWriter(System.out,format);
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
try {
writer.write(doc);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} } public static void StringToDoc(){
/* 将docment对象转换称为xml */
/*Document doc=createDocument();
String text=doc.asXML();
System.out.println(text);*/
/* 将text对象转换称为document*/
String text="<a><b>1</b><b>2</b><b>3</b></a>";
try {
Document document=DocumentHelper.parseText(text);
treeWalk(document);
} catch (DocumentException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
} public static Document a(Document doc,String stylesheet) throws IOException{
TransformerFactory factory=TransformerFactory.newInstance();
Transformer transformer = null;
try {
transformer=factory.newTransformer(new StreamSource(stylesheet));
} catch (TransformerConfigurationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} DocumentSource source=new DocumentSource(doc);
DocumentResult result=new DocumentResult();
try {
transformer.transform( source, result );
} catch (TransformerException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
Document transformedDoc = result.getDocument();
XMLWriter writer = null; writer=new XMLWriter(new FileWriter("doc.doc"));
writer.write(transformedDoc); return transformedDoc;
} }

简单使用dom4j的更多相关文章

  1. 简单用DOM4J结合XPATH解析XML

    由于DOM4J在解析XML时只能一层一层解析,所以当XML文件层数过多时使用会很不方便,结合XPATH就可以直接获取到某个元素 使用dom4j支持xpath的操作的几种主要形式    第一种形式   ...

  2. 详细说明XML分解(两)—DOM4J

    第一部分关于博客XML三接口,同时也为学习DOM4J该分析工具做准备.一般解析器基本上都实现了DOM和SAX这两组接口,DOM4J自然也不例外..DOM4J仅仅是经常使用解析器的当中一种,只是既然是实 ...

  3. 【java项目实战】dom4j解析xml文件,连接Oracle数据库

    简单介绍 dom4j是由dom4j.org出品的一个开源XML解析包.这句话太官方.我们还是看一下官方给出的解释.例如以下图: dom4j是一个易于使用的.开源的,用于解析XML,XPath和XSLT ...

  4. dom4j的测试例子和源码详解(重点对比和DOM、SAX的区别)

    目录 简介 DOM.SAX.JAXP和DOM4J xerces解释器 SAX DOM JAXP DOM解析器 获取SAX解析器 DOM4j 项目环境 工程环境 创建项目 引入依赖 使用例子--生成xm ...

  5. dom4j解析器 基于dom4j的xpath技术 简单工厂设计模式 分层结构设计思想 SAX解析器 DOM编程

    *1 dom4j解析器   1)CRUD的含义:CreateReadUpdateDelete增删查改   2)XML解析器有二类,分别是DOM和SAX(simple Api for xml).     ...

  6. dom4j 简单使用

    1,需要用到dom4j的jar包.为了打开xml方便,设计一个简单的封装类. package cn.com.gtmc.glaf2.util; import java.io.File; import j ...

  7. java 开发中 dom4j的简单用法

    Java中处理XML的方式有很多种,个人任务dom4j还是比较好用的.下面介绍以下简单的使用方法 先把import补充上 import org.dom4j.Document; import org.d ...

  8. dom4j最常用最简单的方法

    要使用dom4j读写XML文档,需要先下载dom4j包,dom4j官方网站在 http://www.dom4j.org/目前最新dom4j包下载地址:http://nchc.dl.sourceforg ...

  9. java代码用dom4j解析xml文件的简单操作

    时间: 2016/02/17 目标:为telenor的ALU Femto接口写一个采集xml文件并解析出locationName标签里的值,然后更新到数据库中. 从网上搜了下,有四种常用的解析xml的 ...

随机推荐

  1. Nginx 使用总结

    一.使用 nginx 实现 灰度发布 灰度发布,现在是很多大项目的一个标配运维特性,我们可以将一个“新的版本代码”发布到集群中的少数几台(组)机器上,以便引入线上少量真实用 户进行测试,用于验证产品改 ...

  2. 使用Navicat连接Mysql报错:can not get hostname for your address

    以管理员的身份使用cmd命令运行netsh winsock reset即可!

  3. 在SQL Server里如何进行数据页级别的恢复

    在SQL Server里如何进行页级别的恢复 关键词:数据页修复 在今天的文章里我想谈下每个DBA应该知道的一个重要话题:在SQL Server里如何进行页级别还原操作.假设在SQL Server里你 ...

  4. 循环链表的实现与操作(C语言实现)

    循环链表是还有一种形式的链式存贮结构.它的特点是表中最后一个结点的指针域指向头结点,整个链表形成一个环. 循环链表的操作 1,循环链表的新操作 2, 获取当前游标指向的数据元素 3, 将游标重置指向链 ...

  5. [py]python中的==和is的区别

    is比较id id(a) == id(b) == id(c) a is d #false ==比较值 a==b #true 举个例子:a = 1 b = a c = 1 d = 1.0 这里有3个对象 ...

  6. Java面向对象---重写(Override)与重载(Overload)

    一.重写(Override) 重写是子类对父类的允许访问的方法的实现过程进行重新编写, 返回值和形参都不能改变.即外壳不变,核心重写! 重写的好处在于子类可以根据需要,定义特定于自己的行为. 也就是说 ...

  7. java--jvm启动的参数

    java启动参数共分为三类其一是标准参数(-),所有的JVM实现都必须实现这些参数的功能,而且向后兼容:其二是非标准参数(-X),默认jvm实现这些参数的功能,但是并不保证所有jvm实现都满足,且不保 ...

  8. Centos7.5 升级python3.6

    Centos7.5自带为/usr/bin/python2.7,需升级到python3.6,安装非常简单,直接通过yum. #centos7 pythonyum install epel-release ...

  9. Java实现文本创建、删除、编辑内容

    Java实现文本创建.删除.编辑内容 1,创建文本代码: //创建文件并追加内容 public static void writeContentToTxt(StringBuffer Content,F ...

  10. Win7系统(台式机)设置系统的窗口背景色(豆沙绿色)

    Win7系统(台式机)设置系统的窗口背景色(豆沙绿色) 1,桌面->右键->个性化->窗口颜色->高级外观设置->项目选择(窗口).颜色1(L)选择(其它)将色调改为:8 ...