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 ...
随机推荐
- linux安装curl出错
今天配置一台server的php支持curl的时候, 出现如下报错 checking for cURL in default path... not foundconfigure: error: Pl ...
- Django基础之简介(二)
三板斧 from django.shortcuts import render,HttpResponse, redirect HttpResponse # 返回字符串 urls: urlpatte ...
- Robot Framework 源码阅读 day1 __main__.py
robot文件夹下的__main__.py函数 是使用module运行时的入口函数: import sys # Allows running as a script. __name__ check n ...
- Linux性能优化从入门到实战:16 文件系统篇:总结磁盘I/O指标/工具、问题定位和调优
(1)磁盘 I/O 性能指标 文件系统和磁盘 I/O 指标对应的工具 文件系统和磁盘 I/O 工具对应的指标 (2)磁盘 I/O 问题定位分析思路 (3)I/O 性能优化思路 Step 1:首先采用 ...
- nginx安装配置_runoob_阅读笔记_20190917
Nginx 安装配置_runoob菜鸟教程 Nginx 安装配置 Nginx("engine x")是一款是由俄罗斯的程序设计师Igor Sysoev所开发高性能的 Web和 反向 ...
- mysql优化-覆盖索引查询,join
1 原始sql: SELECT a.* FROM event_data a WHERE a.receive_time >= '2018-03-28 00:00:00' AND a.receive ...
- prufer 序列 学习笔记
prufer 序列是一种无根树的序列,对于一个 \(n\) 个点的树,其 prufer 序列的长度为 \(n-2\). prufer 序列和原树之间都可以唯一地相互转化. 构造 构造 prufer 序 ...
- ubuntu idea 安装
一.下载 1.进入官网 下载对应安装包 https://www.jetbrains.com/idea/download/#section=linux sudo wget https://downloa ...
- ArrayList,Vector, LinkedList的存储性能和特性?
ArrayList,Vector, LinkedList的存储性能和特性? ArrayList 采用的是数组形式来保存对象的,这种方式将对象放在连续的位置中,所以最大的缺点就是插入或删除时非常麻烦. ...
- flask之显示当地时间
一:在网页上显示时间 flask-moment 程序扩展可以实现 pip install flask-moment # 未完待续