org.dom4j 解析XML
org.dom4j 解析xml java 代码
1 import java.io.File;
import java.io.FileOutputStream;
import java.io.FileWriter;
import java.io.OutputStreamWriter;
import java.util.Iterator;
import java.util.List;
import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;
/**
* element:元素
* attribute:属性
* Document*read(File file)从指定文件中读取文档
* Element*element(String name) 返回第一个元素为给定的本地名称和命名空间。
* List*elements()返回此元素中包含的元素。
* List*elements(String name) 返回该元素中包含的元素与给定的本地名称和命名空间。
* Attribute*attribute(String name)返回给定名称的属性
* List*attributes()返回该元素包含该属性的实例作为一个支持列表,这样可能被修改的属性直接使用列表界面
* String*getName()返回此节点的名称
* String*getValue() 返回该属性的值。
* Element*getRootElement() 返回文档的根元素。
* String*getText() 返回该元素的文本值没有通过递归子元素。
* void*setText(String text)设置文本数据的节点 或这个方法会抛出一个不支持的操作异常,如果它是只读的。
* static OutputFormat*createPrettyPrint() 一个静态的助手方法来创建默认的打印格式。
* Element*addText(String text) 添加一个新的文本节点与给定的文本元素。
* Element*addCDATA(String cdata) 添加一个新的CDATA节点与给定的文本元素。
* Element*addElement(String name) 添加一个新元素节点的名字这个分支,并返回一个新节点的引用。
* Element*addAttribute(String name, String value)增加的属性值给定的本地名称。
* void*write(Document doc)这将打印当前命令的文档。
*/ public class DOM4J_CURD_XML {
public static void main(String[] args) {
try { new DOM4J_CURD_XML().test(); } catch (Exception e) {
e.printStackTrace();
}
} /**
* 删除属性、节点。
* 添加属性、节点。
*
*/
public void test() throws Exception {
// 创建saxReader对象
SAXReader reader = new SAXReader();
// 通过read方法读取一个文件 转换成Document对象
Document document = reader.read(new File("src/sdmz.xml"));
//获取根节点元素对象
Element node = document.getRootElement();
//遍历所有的元素节点 方法1
listNodes(node); //查看==========================================
//遍历所有的元素节点 方法2
//elementMethod(node); //查看========================================== // 获取四大名著元素节点中,子节点名称为红楼梦元素节点。
Element element = node.element("红楼梦");
//获取element的id属性节点对象
Attribute attribu = element.attribute("id");
//删除属性
element.remove(attribu); //删除========================================= //添加新的属性
element.addAttribute("name", "曹雪芹"); //增加(属性 )======================= //获取element中的作者元素节点对象
Element sex = element.element("性别");
//删除元素节点
boolean flag = element.remove(sex); //删除节点======================
//返回true代码删除成功,否则失败
System.out.println(flag+"操作成功");
Element author = element.element("作者");
author.setName("读者"); //更改节点名==================================
author.setText("刘杨"); //更改节点内容================================= // 在红楼梦元素节点中添加朝代元素的节点
Element newElement = element.addElement("朝代"); //增加(节点)==============
newElement.addText("清朝"); //增加(节点内容)======================= //添加CDATA区域
element.addCDATA("红楼梦,是一部爱情小说."); //增加(CDATA)=====================
// 写入到一个新的文件中
writer(document);
} /**
* 把document对象写入新的文件
*
*/
public void writer(Document document) throws Exception {
// // 排版紧凑的格式
// OutputFormat format = OutputFormat.createCompactFormat();
// 排版缩进的格式
OutputFormat format = OutputFormat.createPrettyPrint();
// 设置编码
format.setEncoding("UTF-8");
// 创建XMLWriter对象,指定了写出文件及编码格式
XMLWriter writer = new XMLWriter(new FileWriter(new File("src/sdmz2.xml")),format);
//XMLWriter writer = new XMLWriter(new OutputStreamWriter(new FileOutputStream(new File("src/sdmz2.xml")), "UTF-8"), format);
// 写入
writer.write(document);
// 立即写入
writer.flush();
// 关闭操作
writer.close();
} /**
* 遍历所有的元素节点 方法1
* 遍历当前节点元素下面的所有(元素的)子节点
*
*/
public void listNodes(Element node) {
System.out.println("当前节点的名称:" + node.getName());
// 获取当前节点的所有属性节点
List<Attribute> list = node.attributes();
// 遍历属性节点,获得属性名称及属性值
for (Attribute attr : list) {
System.out.println(attr.getName()+ " -- =" + attr.getValue());
} //获得节点的文本内容
if (!(node.getTextTrim().equals(""))) { //去空格,看是否为空
System.out.println("文本内容:" + node.getText());
} // 当前节点下面子节点迭代器
Iterator<Element> it = node.elementIterator();
// 遍历
while (it.hasNext()) {
// 获取某个子节点对象
Element e = it.next();
// 对子节点进行遍历
listNodes(e);
}
} /**
* 遍历所有的元素节点 方法2
* 介绍Element中的element方法和elements方法的使用
*
*/
public void elementMethod(Element node) {
// 获取node节点中,子节点的元素名称为西游记的元素节点。
Element e = node.element("西游记");
// 获取西游记元素节点中,子节点为作者的元素节点(可以看到只能获取第一个作者元素节点)
Element author = e.element("作者");
System.out.println(e.getName() + " --- =" + author.getText()); // 获取西游记这个元素节点 中,所有子节点名称 为作者 元素的节点 。
List<Element> authors = e.elements("作者");
for (Element auts : authors) {
System.out.println(auts.getText());
}
// 获取西游记这个元素节点 所有元素的子节点。
List<Element> elements = e.elements();
for (Element el : elements) {
System.out.println(el.getText());
}
} }
2. sdmz.xml
<?xml version="1.0" encoding="UTF-8"?>
<四大名著>
<西游记 id="x001">
<作者>吴承恩1</作者>
<作者>吴承恩2</作者>
<朝代>明朝</朝代>
</西游记>
<红楼梦 id="x002">
<作者>曹雪芹</作者>
<性别>男</性别>
</红楼梦>
</四大名著>
3. 运行结果:sdmz2.xml
<?xml version="1.0" encoding="UTF-8"?>
<四大名著>
<西游记 id="x001">
<作者>吴承恩1</作者>
<作者>吴承恩2</作者>
<朝代>明朝</朝代>
</西游记>
<红楼梦 name="曹雪芹">
<读者>刘杨</读者>
<朝代>清朝</朝代>
<![CDATA[红楼梦,是一部爱情小说.]]>
</红楼梦>
</四大名著>
org.dom4j 解析XML的更多相关文章
- java中采用dom4j解析xml文件
		一.前言 在最近的开发中用到了dom4j来解析xml文件,以前听说过来解析xml文件的几种标准方式:但是从来的没有应用过来,所以可以在google中搜索dmo4j解析xml文件的方式,学习一下dom4 ... 
- 转:在java中使用dom4j解析xml
		JAVA 使用Dom4j 解析XML Java DOM4J Parser - Parse XML Document Dom4j下载及使用Dom4j读写XML简介 在java中使用dom4j解析xml ... 
- Dom4j解析xml
		public class Dom4jTest { // Dom4j解析xml // 因为所有的方法都需要Dom树 static Document document = null; static Ele ... 
- 使用dom4j解析XML文档
		dom4j的包开源包,不属于JDK里面,在myeclipse中要单独导入在项目中,这里不累赘了 做这个过程,很慢,因为很多方法没用过不熟悉,自己得去查帮助文档,而且还得去试,因为没有中文版,英文翻译不 ... 
- 【JAVA使用XPath、DOM4J解析XML文件,实现对XML文件的CRUD操作】
		一.简介 1.使用XPath可以快速精确定位指定的节点,以实现对XML文件的CRUD操作. 2.去网上下载一个“XPath帮助文档”,以便于查看语法等详细信息,最好是那种有很多实例的那种. 3.学习X ... 
- 用DOM4J解析XML文件案例
		用DOM4J解析XML文件案例,由于DOM4J不像JAXP属于JAVASE里,所以如果要使用DOM4J,则必须额外引入jar包,如图: 
- java使用dom4j解析xml文件
		关于xml的知识,及作用什么的就不说了,直接解释如何使用dom4j解析.假如有如下xml: dom4j解析xml其实很简单,只要你有点java基础,知道xml文件.结合下面的xml文件和java代码, ... 
- 【收藏用】--切勿转载JAVA 使用Dom4j 解析XML
		原帖地址 : http://blog.csdn.NET/yyywyr/article/details/38359049 解析XML的方式有很多,本文介绍使用dom4j解析xml. 1.环境准备 (1) ... 
- 使用DOM4J解析XMl文件与读取XML文件
		XML文件 <?xml version="1.0" encoding="UTF-8"?> <bookstore> <book id ... 
- Dom4j解析Xml文件,Dom4j创建Xml文件
		Dom4j解析Xml文件,Dom4j创建Xml文件 >>>>>>>>>>>>>>>>>>&g ... 
随机推荐
- ES6新数据类型Symbol
			Symbol 需计算字面量属性时使用 const benz = Symbol('benz'); const car = { [benz]: 'benz car' }; const info = Sym ... 
- [Bzoj3262]陌上花开(CDQ分治&&树状数组||树套树)
			题目链接 题目就是赤裸裸的三维偏序,所以用CDQ+树状数组可以比较轻松的解决,但是还是树套树好想QAQ CDQ+树状数组 #include<bits/stdc++.h> using nam ... 
- linux内核的gpiolib详解
			#include <linux/init.h> // __init __exit #include <linux/module.h> // module_init module ... 
- HTML5随记
			1.浏览器加载HTML的过程是从上至下,因此引用的第三方js文件一定要放到自己定义的js文件的前面,否则引入的js文件将会在加载时失效. 2.html的全局属性包括:accesskey.content ... 
- 洛谷P3502 [POI2010]CHO-Hamsters感想及题解(图论+字符串+矩阵加速$dp\&Floyd$)
			洛谷P3502 [POI2010]CHO-Hamsters感想及题解(图论+字符串+矩阵加速\(dp\&Floyd\)) 标签:题解 阅读体验:https://zybuluo.com/Junl ... 
- exec 命令
			source source命令即点(.)命令. 在bash下输入man source,找到source命令解释处,可以看到解释”Read and execute commands from filen ... 
- CSU-1110 RMQ with Shifts (单点更新+区间最小值 zkw线段树)
			In the traditional RMQ (Range Minimum Query) problem, we have a static array A. Then for each query ... 
- python中的垃圾回收机制及原理
			序言: 来一起看看: 不同于C/C++,像Python这样的语言是不需要程序员写代码来管理内存的,它的GC(Garbage Collection)机制 实现了自动内存管理.GC做的事情就是解放程序员的 ... 
- vue.js  笔记
			<!-- 多层for循环 --> <ul> <li v-for="(ite,key) in list2"> {{key}}-------{{it ... 
- 洛谷P2606 [ZJOI2010]排列计数  组合数学+DP
			题意:称一个1,2,...,N的排列P1,P2...,Pn是Magic的,当且仅当2<=i<=N时,Pi>Pi/2. 计算1,2,...N的排列中有多少是Magic的,答案可能很大, ... 
