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的更多相关文章

  1. java中采用dom4j解析xml文件

    一.前言 在最近的开发中用到了dom4j来解析xml文件,以前听说过来解析xml文件的几种标准方式:但是从来的没有应用过来,所以可以在google中搜索dmo4j解析xml文件的方式,学习一下dom4 ...

  2. 转:在java中使用dom4j解析xml

    JAVA 使用Dom4j 解析XML Java DOM4J Parser - Parse XML Document Dom4j下载及使用Dom4j读写XML简介 在java中使用dom4j解析xml ...

  3. Dom4j解析xml

    public class Dom4jTest { // Dom4j解析xml // 因为所有的方法都需要Dom树 static Document document = null; static Ele ...

  4. 使用dom4j解析XML文档

    dom4j的包开源包,不属于JDK里面,在myeclipse中要单独导入在项目中,这里不累赘了 做这个过程,很慢,因为很多方法没用过不熟悉,自己得去查帮助文档,而且还得去试,因为没有中文版,英文翻译不 ...

  5. 【JAVA使用XPath、DOM4J解析XML文件,实现对XML文件的CRUD操作】

    一.简介 1.使用XPath可以快速精确定位指定的节点,以实现对XML文件的CRUD操作. 2.去网上下载一个“XPath帮助文档”,以便于查看语法等详细信息,最好是那种有很多实例的那种. 3.学习X ...

  6. 用DOM4J解析XML文件案例

    用DOM4J解析XML文件案例,由于DOM4J不像JAXP属于JAVASE里,所以如果要使用DOM4J,则必须额外引入jar包,如图:

  7. java使用dom4j解析xml文件

    关于xml的知识,及作用什么的就不说了,直接解释如何使用dom4j解析.假如有如下xml: dom4j解析xml其实很简单,只要你有点java基础,知道xml文件.结合下面的xml文件和java代码, ...

  8. 【收藏用】--切勿转载JAVA 使用Dom4j 解析XML

    原帖地址 : http://blog.csdn.NET/yyywyr/article/details/38359049 解析XML的方式有很多,本文介绍使用dom4j解析xml. 1.环境准备 (1) ...

  9. 使用DOM4J解析XMl文件与读取XML文件

    XML文件 <?xml version="1.0" encoding="UTF-8"?> <bookstore> <book id ...

  10. Dom4j解析Xml文件,Dom4j创建Xml文件

    Dom4j解析Xml文件,Dom4j创建Xml文件 >>>>>>>>>>>>>>>>>>&g ...

随机推荐

  1. 洛谷 P1462 通往奥格瑞玛的道路(二分答案,堆优化dijkstra)

    传送门 解题思路 首先看题目问题,求经过的所有城市中最多的一次收取的费用的最小值是多少.一看“最大值最小”就想到了二分答案. 在读一遍题目,就是二分收取的费用,然后对于每一个二分的费用,跑一边最短路, ...

  2. 待补 http://acm.hdu.edu.cn/showproblem.php?pid=6602

    http://acm.hdu.edu.cn/showproblem.php?pid=6602 终于能够看懂的题解: https://blog.csdn.net/qq_40871466/article/ ...

  3. 7、purge_haplogs 基因组去冗余

    1.下载安装 https://bitbucket.org/mroachawri/purge_haplotigs/wiki/Install 1.Dependencies (in no particula ...

  4. VUE组件嵌套

    vue中组件嵌套烦分为两种,分别是全局注册组件和局部注册组件 基本步骤: 1.在components 下创建一个新的.vue结尾的文件,文件首字母最好是大写,基于规范复制代码 2.分别写出结构层< ...

  5. MySQL语句之数据的增删改查

    1.插入记录insert语法:INSERT INTO tablename (field1,field2,……fieldn) VALUES(value1,value2,……valuesn); 也可以一次 ...

  6. vue中对于图片是否正常加载的思考

    问题:由于业务需要,我们需要判断图片能否正常的加载,如果未正常加载的话,需要显示一张默认图片: 方案:1,由于后台返回的是一个图片id数组,例如 imgList=['343313131','21333 ...

  7. Django 路由层与视图层

    1.路由层 1.1无名分组 1.2 有名分组 1.3 反向解析 1.4 路由分发 1.5 名称空间 2.伪静态网页 3.虚拟环境 4.视图层 1.1 JsonResponse 1.2 FBV与CBV ...

  8. [NOI1999]生日蛋糕(搜索)

    [NOI1999]生日蛋糕 题目背景 7月17日是Mr.W的生日,ACM-THU为此要制作一个体积为Nπ的M层 生日蛋糕,每层都是一个圆柱体. 设从下往上数第i(1<=i<=M)层蛋糕是半 ...

  9. Windows系统中,循环运行.bat/.exe等文件

    一.创建循环运行的run-everySecond.vbs文件[双击次文件即可启动运行] dim a set a=CreateObject("Wscript.Shell") Do # ...

  10. generator (2)

    generator 的使用 第一次调用next  时  传参没有任何意义  打印不出来任何结果 function * read(){ let a = yield 1; console.log(a); ...