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. 百度文档,用Python一键免费下载

    百度文库下载需要券,或者vip才能下载 Vip价格高,偶尔下载一次不划算. 不下载复制?不好意思复制也需要vip否则只能一次复制两行. 如何才能以最低成本获取到百度文库里的文档内容呢? 当然是用Pyt ...

  2. Appium+Python之PO模型(Page object Model)

    思考:我们进行自动化测试时,如果把代码都写在一个脚本中,代码的可读性会变差,且后期代码维护也麻烦,最好的想法就是测试对象和测试用例可以分离,可以很快定位问题,代码可读性高,也比较容易理解.这里推荐大家 ...

  3. 二分查找---有序数组的 Single Element

    有序数组的 Single Element 540. Single Element in a Sorted Array (Medium) Input: [1, 1, 2, 3, 3, 4, 4, 8, ...

  4. C#中的==和Equals的区别

    一,值类型中的比较,对于值类型,如果对象的值相等,则相等运算符 (==) 返回 true,否则返回 false. ; ; bool bi1 = ai.Equals(bi); //true bool b ...

  5. JavaScript基础9——操作DOM树

    appendChild()方法:添加子节点到末尾 类似于剪切粘贴的效果   insertBefore(newNode, oldNode)方法:在某个节点之前插入一个节点 newNode为要插入的节点, ...

  6. Django 路由层与视图层

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

  7. 2018-8-10-win10-uwp-读写XML

    title author date CreateTime categories win10 uwp 读写XML lindexi 2018-08-10 19:16:51 +0800 2018-2-13 ...

  8. 12 | 为什么我的MySQL会“抖”一下? 学习记录

    <MySQL实战45讲>12 | 为什么我的MySQL会“抖”一下? 学习记录 http://naotu.baidu.com/file/15aa54cab2fa882c6a2a1dd52e ...

  9. 一、ARM

    1.1 ARM 分类 1.1.1 版本号分类 以前分类的是 ARM7,ARM9... ARM11,在 ARM11 之后,就是以 Cortex 系列分类了: Cortex-R:应用在实时系统上的系列 C ...

  10. $LCT$维护子树信息学习笔记

    \(LCT\)维护子树信息学习笔记 昨天\(FDF\)好题分享投了 \([ZJOI2018]\)历史 这题. 然后我顺势学学这个姿势. 结果调了一年...于是写个笔记记录一下. 基本原理 比较显然地, ...