1.导入dim4j提供的jar包

  (1)dom4j,是一个组织,针对xml解析,提供解析器dom4j

  (2)dom4j不是javase的一部分(jaxp是的)

  (3)使用dom4j步骤

    - 下载并导入dom4j提供的jar包

    - 创建一个lib文件夹,并把jar包放到里面

    - 右键点击jar包, build path --> add to buildpath

    - 看到jar包变成一个奶瓶养殖,表示导入成功

  (4)下载地址  https://dom4j.github.io/  下载后缀名为 .zip的文件 它里面提供了许多帮助文档

  (5)查看快速开发

    - 解压后 dom4j-1.6.1-->docs-->打开index.html-->点击左上角的 Quick start  我们可以看到很多实例

  (6)在线api文档地址 https://www.oschina.net/uploads/doc/dom4j-1.6.1/index.html

2.解析xml

  (1)获取document(SAXReader creates a DOM4J tree from SAX parsing events.)

//获取解析器
SAXReader saxReader = new SAXReader();
//获取文档
Document document = saxReader.read("xml文件路径");

  (2)document的父接口是Node

    - Node中的一些方法

        getName()       获取元素名
        getParent()      获取元素的父元素
        getText()       获取元素的值
        setText(String text) 修改元素的值(这个会覆盖原来的值)

    - document接口的一些方法

        getRootElement()  获取xml的根元素,返回Element

  (3)Element父接口Node

    - Element中的一些方法

        addAttribute(String name, String value)   给元素添加属性

        addText(String text)   在元素原有的值上追加文字

        attributeValue(String name) 获取元素的属性值

        attributeIterator()    返回一个Iterator迭代器

  (4)如果我们对xml进行了增删改,那么我们需要更新xml文件

OutputFormat format = OutputFormat.createPrettyPrint();
XMLWriter xmlWriter = new XMLWriter(new FileOutputStream("src/Day3/text.xml"),format);
xmlWriter.write(document);
xmlWriter.close();

 OutputFormat.createPrettyPrint()  : 表示格式化(就是有缩进的格式)

3.实例如下

xml文件如下:

<?xml version="1.0" encoding="UTF-8"?>

<persion>
<p ID="AAA">
<name>李四</name>
<age>88</age>
</p>
<p>
<name>张三</name>
<age>55</age>
</p>
</persion>

//需求1:获取xml中所有的name元素的值

package Day3;

import java.util.List;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader; public class Demo1 {
public static void main(String[] args) throws Exception {
//创建解析器
SAXReader saxReader = new SAXReader();
//得到document
Document document = saxReader.read("src/Day3/text.xml");
//获取根节点
Element element = document.getRootElement();
//获取所有p元素
List<Element> list = element.elements("p");
//遍历p元素
for (Element p : list) {
//获取每个p元素中的name元素
Element name = p.element("name");
//获取name元素的值
String str = name.getText();
//输出
System.out.println(str);
}
}
}

//需求2:查询第一个p元素中的name元素的值

package Day3;

import java.util.List;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader; public class Demo2 {
public static void main(String[] args) throws Exception {
//获取解析器(org.dom4j.io.SAXReader)
SAXReader saxReader = new SAXReader();
//获取文档(org.dom4j.Document)
Document document = saxReader.read("src/Day3/text.xml");
//获取根元素(org.dom4j.Element)
Element element = document.getRootElement();
//获取所有的p元素(List集合 java.util.List)
List<Element> list = element.elements("p");
//获取第一个p元素
Element p1 = list.get(0);
//获取第一个name元素
Element name1 = p1.element("name");
//输出第一个name元素的值
System.out.println(name1.getText());
}
}

//需求3:在第一个p元素里面添加一个元素<sex>女</sex>

package Day3;

import java.io.FileOutputStream;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter; public class Demo3 {
public static void main(String[] args) throws Exception {
//获取解析器
SAXReader saxReader = new SAXReader();
//获取document
Document document = saxReader.read("src/Day3/text.xml");
//获取根元素
Element element = document.getRootElement();
//获取第一个p元素
Element p1 = element.element("p");
//在p1里面添加一个标签(<sex>女</sex>)
Element sex = p1.addElement("sex");
//在新添加的标签里面写入文字
sex.setText("女");
//更新xml文件
OutputFormat format = OutputFormat.createPrettyPrint();
XMLWriter xmlWriter = new XMLWriter(new FileOutputStream("src/Day3/text.xml"), format);
xmlWriter.write(document);
xmlWriter.close();
}
}

//需求4:在指定地方添加元素<school>家里蹲大学</school>

package Day3;

import java.io.FileOutputStream;
import java.util.List;
import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter; public class Demo4 {
public static void main(String[] args) throws Exception {
//获取解析器
SAXReader saxReader = new SAXReader();
//获取document
Document document = saxReader.read("src/Day3/text.xml");
//获取根元素
Element element = document.getRootElement();
//获取第一个p元素
Element p = element.element("p");
//获取p元素中的所有元素
List<Element> list = p.elements();
//创建需要添加的元素
Element addElement = DocumentHelper.createElement("school");
//在创建的元素中写入文字
addElement.setText("家里蹲大学");
//把创建的元素添加到集合指定的地方
list.add(1, addElement);
//更新xml文件
OutputFormat format = OutputFormat.createPrettyPrint();
XMLWriter xmlWriter = new XMLWriter(new FileOutputStream("src/Day3/text.xml"),format);
xmlWriter.write(document);
xmlWriter.close(); }
}

//需求5:修改第一个p元素中的age元素的值

package Day3;

import java.io.FileOutputStream;

import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter; public class Demo5 {
public static void main(String[] args) throws Exception {
//获取解析器
SAXReader saxReader = new SAXReader();
//获取document
Document document = saxReader.read("src/Day3/text.xml");
//获取根元素
Element element = document.getRootElement();
//获取第一个p元素
Element p = element.element("p");
//获取第一个p元素的age元素
Element age = p.element("age");
//修改第一个p元素的age元素的值为30
age.setText("30");
//更新xml
OutputFormat format = OutputFormat.createPrettyPrint();
XMLWriter xmlWriter = new XMLWriter(new FileOutputStream("src/Day3/text.xml"),format);
xmlWriter.write(document);
xmlWriter.close();
}
}

//需求6:删除第二个p元素的name元素

package Day3;

import java.io.FileOutputStream;
import java.util.List; import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter; public class Demo6 {
public static void main(String[] args) throws Exception {
//获取解析器
SAXReader saxReader = new SAXReader();
//获取document
Document document = saxReader.read("src/Day3/text.xml");
//获取根元素
Element element = document.getRootElement();
//获取所有p元素
List<Element> list = element.elements("p");
//获取第二个p元素
Element p2 = list.get(1);
//获取第二个p元素的name元素
Element name = p2.element("name");
//通过父元素删除子元素(要被删除的元素)
p2.remove(name);
//更新xml文件
OutputFormat format = OutputFormat.createPrettyPrint();
XMLWriter xmlWriter = new XMLWriter(new FileOutputStream("src/Day3/text.xml"),format);
xmlWriter.write(document);
xmlWriter.close();
}
}

//需求7:获取第一个p元素的ID值

package Day3;

import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader; public class Demo7 {
public static void main(String[] args) throws Exception {
//获取解析器
SAXReader saxReader = new SAXReader();
//获取document
Document document = saxReader.read("src/Day3/text.xml");
//获取根元素
Element element = document.getRootElement();
//获取第一个p元素
Element p = element.element("p");
//获取第一个p元素的ID值
String strid = p.attributeValue("ID");
//输出
System.out.println(strid);
}
}

7.使用dom4j实现增删改查的更多相关文章

  1. 使用dom4j对xml文件进行增删改查

    1.使用dom4j技术对dom_demo.xml进行增删改查 首选要下载dom4j的jar包 在官网上找不到,网上搜索了一下在这个链接:http://sourceforge.net/projects/ ...

  2. 用dom4j解析xml文件并执行增删改查操作

    转自:https://www.aliyun.com/jiaocheng/1339446.html xml文件: <?xml version="1.0" encoding=&q ...

  3. XML(五)dom4j增删改查

    book2.xml <? xml version="1.0" encoding="UTF-8"?> <书架> <书> < ...

  4. 使用DOM进行xml文档的crud(增删改查)操作<操作详解>

    很多朋友对DOM有感冒,这里我花了一些时间写了一个小小的教程,这个能看懂,会操作了,我相信基于DOM的其它API(如JDOM,DOM4J等)一般不会有什么问题. 后附java代码,也可以下载(可点击这 ...

  5. XML为数据库进行增删改查(实例)

    //增删改查文件 package xml2; import java.io.BufferedReader;import java.io.BufferedWriter;import java.io.Fi ...

  6. java实现xml文件增删改查

    java一次删除xml多个节点: 方案1.你直接改动了nodeList,这一般在做循环时是不同意直接这么做的. 你能够尝试在遍历一个list时,在循环体同一时候删除list里的内容,你会得到一个异常. ...

  7. sssp-springmvc+spring+spring-data-jpa增删改查

    环境:IDE:eclipse.jdk1.7.mysql5.7.maven 项目结构图 上面目录结构你可以自己创建 搭建框架 首先加入maven依赖包以及相关插件 <dependencies> ...

  8. java中XML操作:xml与string互转、读取XML文档节点及对XML节点增删改查

    一.XML和String互转: 使用dom4j程式变得很简单 //字符串转XML String xmlStr = \"......\"; Document document = D ...

  9. 使用idea对XML的增删改查

    XML:是一种可扩展标记性的语言,与java语言无关,它可以自定义标签. 1.首先需要到导入Dom4j架包,与自己所时候的ide关联 2.编写自己的xml文件,入上图所示(里面的所有元素及元素中的属性 ...

随机推荐

  1. hud 4347 The Closest M Points(KD-Tree)

    传送门 解题思路 \(KD-Tree\)模板题,\(KD-Tree\)解决的是多维问题,它是一个可以储存\(K\)维数据的二叉树,每一层都被一维所分割.它的插入删除复杂度为\(log^2 n\),它查 ...

  2. php常用端口号

    常见端口号 Nginx 80 Nginx (“engine x”) 是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP服务器. MySQL 3306 MySQL是一种关系数据 ...

  3. QT_study

    https://blog.csdn.net/a313827758/article/details/72736552 https://blog.csdn.net/xbcreal/article/deta ...

  4. Gym 100917M Matrix, The

    题目链接: http://codeforces.com/gym/100917/problem/M --------------------------------------------------- ...

  5. HDU 5634 Rikka with Phi

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5634 ------------------------------------------------ ...

  6. 穿戴-智能穿戴-ProjectGlass:谷歌眼镜(Google Project Glass)

    ylbtech-穿戴-智能穿戴-ProjectGlass:谷歌眼镜(Google Project Glass) 谷歌眼镜(Google Project Glass)是由谷歌公司于2012年4月发布的一 ...

  7. python实现基于两张图片生成圆角图标效果的方法

    python实现基于两张图片生成圆角图标效果的方法 这篇文章主要介绍了python实现基于两张图片生成圆角图标效果的方法,实例分析了Python使用pil模块进行图片处理的技巧,分享给大家供大家参考. ...

  8. Eclipse+Pydev环境下出现error “eclipse Non-UTF-8 code”

    文件首行加上”#coding=utf-8”   ,这一句话可控制代码中可输入中文字符

  9. jmeter设置全局变量token

    返回登录后的token使用json path Extractor插件,定位到获取后的token为变量 在登录下后置处理器下添加json path Extracto插件 根据上面获取到的token位置路 ...

  10. Spring学习(二)--装配Bean

    一.Spring装配机制 Spring提供了三种主要的装配机制: 1.在XML中进行显示配置 2.在Java中进行显示配置 3.隐式的bean发现机制和自动装配--自动化装配bean Spring可以 ...