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 ...
随机推荐
- P1973 [NOI2011]Noi嘉年华
传送门 首先可以把时间区间离散化 然后求出 $cnt[l][r]$ 表示完全在时间 $[l,r]$ 之内的活动数量 设 $f[i][j]$ 表示当前考虑到时间 $i$,第一个会场活动数量为 $j$ 时 ...
- 14、前端知识点--Vue生命周期浅析
vue生命周期 每个Vue实例或组件从创建到显示再到废弃的过程就是vue的生命周期.很多时候我们希望能在这个过程中执行一些操作,于是就有了生命周期钩子. 生命周期钩子函数允许我们在实例不同阶段执行各种 ...
- d3与echarts的区别
1. 目前各大公司的大数据平台多使用d3还是echarts?什么时候适合用echarts,什么时候适合用d3? 在我看几种数据可视化平台多使用折线图,面积图和柱状图,条图居多,对于echarts和d3 ...
- adb 链接网络 connect 安装apk install 断开IP链接 kill-server 连接数devices
https://blog.csdn.net/zhonglunshun/article/details/78362439 ./adb connetc 192.168.1.11 ./adb install ...
- Anaconda 安装及Python 多版本间切换
安装 Anaconda 安装anaconda 安装较为简单,这里参考官方文档:https://docs.continuum.io/anaconda/install/linux.html 在文件目录下执 ...
- java 类加载及实例化的调用顺序
1.没有继承的情况 单独一个类的场景下,初始化顺序为依次为 静态变量和静态代码块(看两者的书写顺序),继承的基类的构造函数,成员变量,被调用的构造函数. 代码呈现: public class Test ...
- iOS 证书(.p12)和描述文件(.mobileprovision)的导出和使用方法
为什么要导出.p12文件 当我们用大于三个mac设备开发应用时,想要申请新的证书,如果在我们的证书里,包含了3个发布证书,2个开发证书,可以发现再也申请不了开发证书和发布证书了(一般在我们的证书界面中 ...
- ll字段 详解 文件权限
文件类型和权限 硬链接总数 属主用户名 属组组名 文件大小(字节) 上次修改时间 文件/目录名 drwxr-xr-x 15 lb lb 4096 10月 19 01:11 ./ drwxr-xr-x ...
- 二、冯式结构与哈佛结构及ARM处理器状态和处理器模式
2.1 冯式结构与哈佛结构 2.1.1 两者的区别 如果是独立的存储架构和信号通道那就是哈佛结构,否则就是冯式结构 结构与是否统一编址没有关系,也与 CPU 没有关系,与计算机的整体设计有关 CACH ...
- [python 学习] python 多线程
1. # -*- coding: utf-8 -*- import threading import time import random def go(name): for i in range(2 ...