javaweb dom4j解析xml文档
1.什么是dom4j
dom4j是一个Java的XML API,是jdom的升级品,用来读写XML文件的。dom4j是一个十分优秀的JavaXML API,具有性能优异、功能强大和极其易使用的特点,它的性能超过sun公司官方的dom技术,同时它也是一个开放源代码的软件,可以在SourceForge上找到它。在IBM developerWorks上面还可以找到一篇文章,对主流的Java XML API进行的性能、功能和易用性的评测,所以可以知道dom4j无论在哪个方面都是非常出色的。如今可以看到越来越多的Java软件都在使用dom4j来读写XML,特别值得一提的是连Sun的JAXM也在用dom4j。这已经是必须使用的jar包, Hibernate也用它来读写配置文件。
2.如何使用dom4j解析xml文档
(1)在使用dom4j解析xml文档时,首先要到了dom4j的Jar包。
在工作目录下新建一个lib文件夹,把dom4j-1.6.1.jar包拷贝到lib文件夹下,选中dom4j-1.6.1.jar然后build Path就加载好jar包了。
具体操作:代码更直观
需要解析的xml文件(book.xml)
<?xml version="1.0" encoding="UTF-8"?> <书架>
<书>
<书名>java程序设计</书名>
<作者>张三</作者>
<售价>309元</售价>
<售价>45元</售价>
<出版社>南京大学出版社</出版社>
</书>
<书>
<书名>C语言程序设计</书名>
<作者>李四</作者>
<售价>40元</售价>
<出版社>北京大学出版社</出版社>
</书>
</书架>
package DOM4J; import java.io.File;
import java.io.FileOutputStream;
import java.io.FileWriter;
import java.io.OutputStreamWriter;
import java.util.List;
import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;
import org.junit.Test; public class Dom4jDemo {
@Test
//用dom4j读取xml文档
public void read() throws Exception {
//获得DOCUMENT对象
SAXReader reader = new SAXReader();
//获取需要解析文档的路径
Document document = reader.read(new File("src/book.xml"));
Element root = document.getRootElement();
List list = root.elements("书");
String bookname = ((Element) list.get(1)).element("书名").getText();
System.out.println(bookname);
}
@Test
//用dom4j添加节点
public void add() throws Exception {
//获得DOCUMENT对象
SAXReader reader = new SAXReader();
//获取需要解析文档的路径
Document document = reader.read(new File("src/book.xml"));
Element root = document.getRootElement();
List list = root.elements("书");
((Element) list.get(1)).addElement("出版社").setText("北京大学出版社");
//更新内存
// OutputFormat format=OutputFormat.createCompactFormat();//紧凑xml内容
OutputFormat format=OutputFormat.createPrettyPrint();//漂亮xml内容
format.setEncoding("UTF-8"); XMLWriter writer = new XMLWriter(new FileOutputStream("src/book.xml"),format);
writer.write(document);
writer.close();
} @Test
//用dom4j在指点位置添加节点
public void add1() throws Exception {
//获得DOCUMENT对象
SAXReader reader = new SAXReader();
//获取需要解析文档的路径
Document document = reader.read(new File("src/book.xml"));
Element root = document.getRootElement().element("书");
List<Element> list =root.elements();
Element price=DocumentHelper.createElement("售价");
price.setText("309元");
list.add(2, price);
//更新内存
// OutputFormat format=OutputFormat.createCompactFormat();//紧凑xml内容
OutputFormat format=OutputFormat.createPrettyPrint();//漂亮xml内容
format.setEncoding("UTF-8");
//使用文件输入流
XMLWriter writer = new XMLWriter(new FileOutputStream("src/book.xml"),format);
writer.write(document);
writer.close();
}
@Test
//用dom4j在指点位置添加节点
public void delete() throws Exception {
//获得DOCUMENT对象
SAXReader reader = new SAXReader();
//获取需要解析文档的路径
Document document = reader.read(new File("src/book.xml"));
Element root = document.getRootElement().element("书");
List<Element> list =root.elements();
for (Element element : list) {
System.out.println(element.getName());
if(element.getName()=="出版社"){
element.getParent().remove(element);
}
}
//更新内存
// OutputFormat format=OutputFormat.createCompactFormat();//紧凑xml内容
OutputFormat format=OutputFormat.createPrettyPrint();//漂亮xml内容
format.setEncoding("UTF-8");
//使用文件输入流
XMLWriter writer = new XMLWriter(new FileOutputStream("src/book.xml"),format);
writer.write(document);
writer.close();
} @Test
//用dom4j更新数据
public void update() throws Exception {
//获得DOCUMENT对象
SAXReader reader = new SAXReader();
//获取需要解析文档的路径
Document document = reader.read(new File("src/book.xml"));
Element root = document.getRootElement().element("书");
List<Element> list =root.elements();
for (Element element : list) {
if(element.getName()=="出版社"){
element.setText("南京大学出版社");
}
}
//更新内存
// OutputFormat format=OutputFormat.createCompactFormat();//紧凑xml内容
OutputFormat format=OutputFormat.createPrettyPrint();//漂亮xml内容
format.setEncoding("UTF-8");
//使用文件输入流
XMLWriter writer = new XMLWriter(new FileOutputStream("src/book.xml"),format);
writer.write(document);
writer.close();
}
}
javaweb dom4j解析xml文档的更多相关文章
- 使用dom4j解析XML文档
dom4j的包开源包,不属于JDK里面,在myeclipse中要单独导入在项目中,这里不累赘了 做这个过程,很慢,因为很多方法没用过不熟悉,自己得去查帮助文档,而且还得去试,因为没有中文版,英文翻译不 ...
- DOM4J解析XML文档
Tip:DOM4J解析XML文档 Dom4j是一个简单.灵活的开放源代码的库.Dom4j是由早期开发JDOM的人分离出来而后独立开发的.与JDOM不同的是,dom4j使用接口和抽象基类,虽然Dom4j ...
- 使用DOM4J解析XML文档,以及使用XPath提取XML文档
使用DOM4J解析XML文档 需要首先下载DOM4J工具包.这是个第三方工具包 在使用DOM4J解析的时候需要导入 DOM4J的JAR包 下载DOM4J工具包->在MyEclipse中新建lib ...
- 源生API解析XML文档与dom4j解析XML文档
一.XML语言 XML是一种可扩展的标记语言,是一种强类型的语言,类似HTML(超文本标记语言,是一种弱类型的语言).XML是一种通用的数据交换格式(关系型数据库),综上所诉:XML可以传输数据,也可 ...
- 【学习笔记】关于DOM4J:使用DOM4J解析XML文档
一.概述 DOM4J是一个易用的.开源的库,用于XML.XPath和XSLT中.采用了Java集合框架并完全支持DOM.SAX.和JAXP. DOM4J最大的特色是使用大量的接口,主要接口都在org. ...
- dom4j解析xml文档全面介绍
一.dom4j介绍 dom4j是一个Java的XML API,类似于jdom,用来读写XML文件的.dom4j是一个非常非常优秀的Java XML API,具有性能优异.功能强大和极端易用使用的特点, ...
- dom4j解析xml文档&保存数据的乱码问题
package itcast.dom4j; import java.io.File; import java.io.FileOutputStream; import java.io.FileWrite ...
- XML案例(使用DOM4J解析XML文档)
1.Demo1.java package cn.itcast.dom4j; import java.io.File;import java.io.FileOutputStream;import jav ...
- Strus2第一次课:dom4j解析xml文档
xml文本标记语言: 常用于交换数据:独立于操作系统.编程语言数据存储:xml数据配置:灵活性强,可读性高可以使用css样式改变xml样式 xml解析技术:dom解析xml技术: sax解析xml技术 ...
随机推荐
- 通过ssh连接git操作
项目又一次从svn切换到git,而且要求使用安全协议ssh连接git.不管是个人还是组织,git上只负责导入公钥,而不会帮你生成.这里先说下怎么生成这个ssh的私钥和公钥. 首先你得找到有ssh命令的 ...
- 关于urlDecode和tomcat一些源码
1. 看下面源码,找到%号,每次加2,然后将16进制转换为int,也就是%号后两位加2得到16进制,转换为int ) < numChars) && (c=='%')) { ,i+ ...
- TELNET协议规范
ARPA Internet上的主机被要求采用并实现此标准. 介绍 TELNET Protocol的目的是提供一个相对通用的,双向的,面向八位字节的通信方法.它主要的目标是允许接口终端设备的标准方法和面 ...
- 2015 浙江省赛B Team Formation (技巧,动归)
Team Formation For an upcoming programming contest, Edward, the headmaster of Marjar University, is ...
- Java-Maven-Runoob:Maven 引入外部依赖
ylbtech-Java-Maven-Runoob:Maven 引入外部依赖 1.返回顶部 1. Maven 引入外部依赖 如果我们需要引入第三库文件到项目,该怎么操作呢? pom.xml 的 dep ...
- 1125 Chain the Ropes
题意:略. 思路:思考一下,最先拿去对折的绳子会参与之后的每次对折,而对一条绳子而言,对折的次数越多剩下的就越短,因此,要让最终的结果尽可能长,应该先让较短的绳子先对折. 代码: #include & ...
- 转: SQL中的where条件,在数据库中提取与应用浅析
SQL中的where条件,在数据库中提取与应用浅析 http://hedengcheng.com/?p=577 1问题描述 一条SQL,在数据库中是如何执行的呢?相信很多人都会对这个问题比较感兴趣.当 ...
- Linux学习笔记 -- 文本编辑器之 vi与vim
vi/vim 的使用 基本上 vi/vim 共分为三种模式,分别是命令模式(Command mode),插入模式(Insert mode)和底线命令模式(Last line mode). 这三种模式的 ...
- 安全测试回顾(一)补充:burp 的基本操作
浏览器设置; 拦截请求: Spider 伪造请求: 对这个url 伪造请求 拦截一个页面后,进入攻击模块 sniper 两个参数值 保证一个不变 另一个 进行枚举 battering ram 两个 ...
- IDA Pro 权威指南学习笔记(三) - IDA 桌面简介
IDA 的默认桌面如下图 工具栏区域(1)包含与 IDA 的常用操作对应的工具,可以使用 View -> Toolbar 显示或隐藏工具栏 可以使用 View -> Toolbars -& ...