文档章节

dom4j详情

s
 sxl01890
发布于 2016/04/18 08:59
字数 678
阅读 24
收藏 1


src/student.xml

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

<students>

<student number="itcast_0001">

<name>tom</name>

<age>18</age>

<sex>male</sex>

</student>

<student number="itcast_0002">

<name>jerry</name>

<age>16</age>

<sex>female</sex>

</student>

</students>


import java.io.File;


import org.dom4j.Document;

import org.dom4j.DocumentException;

import org.dom4j.io.SAXReader;


public class Demo1 {


/**

*  将xml文档 加载,获得document对象, 

*  将document对象 以字符串的形式输出

* @throws DocumentException 

*/

public static void main(String[] args) throws DocumentException {

//1 创建解析器 

SAXReader reader = new SAXReader();

    //2 使用解析器,加载文档

Document document = reader.read(new File("src/student.xml"));

    //3 将文档对象转化成string

String xml = document.asXML();

      System.out.println(xml);

}


}


import java.io.File;

import java.util.Iterator;


import org.dom4j.Document;

import org.dom4j.DocumentException;

import org.dom4j.Element;

import org.dom4j.io.SAXReader;


public class Demo2 {


/**

* 查 ==> 文档中所有学生信息

* @throws DocumentException 

*/

public static void main(String[] args) throws DocumentException {

//1 创建解析器 

SAXReader reader = new SAXReader();

    //2 使用解析器,加载文档

Document document = reader.read(new File("src/student.xml"));

//3 获得根元素

Element students = document.getRootElement();

//4 迭代根元素下的所有student元素

Iterator<Element> it =  students.elementIterator("student");

while(it.hasNext()){

Element student = it.next();

//5 获得student元素上的number属性

String number =  student.attributeValue("number");

System.out.println(number);

//6 再找 student元素下的name age sex 子元素

//7 获得子元素的内容

Element nameELe = student.element("name");

String name = nameELe.getText();

String age = student.elementText("age");

String sex = student.elementText("sex");

System.out.println(name+"==>"+age+"==>"+sex);

}

}


}



import java.io.File;

import java.io.FileOutputStream;

import java.io.FileWriter;

import java.io.IOException;

import java.io.OutputStreamWriter;


import org.dom4j.Document;

import org.dom4j.DocumentException;

import org.dom4j.Element;

import org.dom4j.io.OutputFormat;

import org.dom4j.io.SAXReader;

import org.dom4j.io.XMLWriter;


public class Demo3_2 {


/**

* 增: 增加一个学生   itcast_0003 杰克 20 male

* @throws DocumentException 

* @throws IOException 

*/

public static void main(String[] args) throws DocumentException, IOException {

//1 创建解析器 

SAXReader reader = new SAXReader();

    //2 使用解析器,加载文档

Document document = reader.read(new File("src/student.xml"));

//3 获得根元素

Element root  = document.getRootElement();

//4 为根元素添加student子元素,和属性.

Element studentEle = root.addElement("student").addAttribute("number", "itcast_0003");

//5 为student添加 name age sex 子元素和内容

studentEle.addElement("name").addText("杰克");

studentEle.addElement("age").addText("20");

studentEle.addElement("sex").addText("male");

//6 回写

//1>创建格式化器

OutputFormat format = OutputFormat.createPrettyPrint();

format.setEncoding("UTF-8"); //解码  encoding="UTF-8"

//2>创建写入器

//XMLWriter writer = new XMLWriter(new FileWriter("src/student_copy.xml"),format);

//XMLWriter writer = new XMLWriter(new OutputStreamWriter(new FileOutputStream("src/student_copy.xml"),"GBK"),format);

XMLWriter writer = new XMLWriter(new FileOutputStream("src/student_copy.xml") ,format);

//3>将文档写入文件

writer.write(document);

//4>关闭资源

writer.close();

//简单的不乱码的方法: 使用字节流写入, 不要使用字符流. 使用字节流永远不会乱码.

}


}




import java.io.File;

import java.io.FileNotFoundException;

import java.io.FileOutputStream;

import java.io.IOException;

import java.io.UnsupportedEncodingException;


import org.dom4j.Document;

import org.dom4j.DocumentException;

import org.dom4j.Element;

import org.dom4j.io.OutputFormat;

import org.dom4j.io.SAXReader;

import org.dom4j.io.XMLWriter;


public class Demo4_2 {


/**

*  删除: 删除学号为itcast_0001 的学生

* @throws DocumentException 

* @throws IOException 

*/

public static void main(String[] args) throws DocumentException, IOException {

//1 创建解析器 

SAXReader reader = new SAXReader();

    //2 使用解析器,加载文档

Document document = reader.read(new File("src/student.xml"));

//3 定义xpath表达式

String xpath ="//student[@number='itcast_0001']";

//4 根据xpath找出要删除的元素

Element stuEle = (Element) document.selectSingleNode(xpath);

//5 删除

stuEle.getParent().remove(stuEle);

//6回写

//1>新建格式化器

OutputFormat format = OutputFormat.createPrettyPrint();

//2>新建写入器

XMLWriter writer = new XMLWriter(new FileOutputStream("src/student_copy.xml"),format);

//3>写入

writer.write(document);

//4>关闭资源

writer.close();

}


}


© 著作权归作者所有

下一篇: 枚举 实例
s
粉丝 3
博文 117
码字总数 55191
作品 0
浦东
私信 提问
加载中

评论(0)

Hibernate 4.16.Final 发布

Hibernate ORM 4.1.6.Final 刚刚发布,这是一个小的 bug 修复版本,修复了 16 个问题,详情请看 changelog 。 下面是需要注意的几个问题: HHH-6130 - Criteria 查询中没有正确处理联合 map ...

红薯
2012/08/09
1.5K
8
【XML】利用Dom4j读取XML文档以及写入XML文档

Dom4j简介 dom4j是一个Java的XML API,是jdom的升级品,用来读写XML文件的。dom4j是一个十分优秀的JavaXML API,具有性能优异、功能强大和极其易使用的特点,它的性能超过sun公司官方的dom技...

osc_mwqvsfzo
2019/07/17
9
0
Java XML解析工具 dom4j介绍及使用实例

Java XML解析工具 dom4j介绍及使用实例 dom4j介绍   dom4j的项目地址:http://sourceforge.net/projects/dom4j/?source=directory   dom4j是一个简单的开源库,用于处理XML、 XPath和XSL...

osc_nmo72btw
2019/05/30
4
0
DOM4J解析XML

Dom4j是一个易用的、开源的库,用于XML,XPath和XSLT。它应用于Java平台,采用了Java集合框架并完全支持DOM,SAX和JAXP。很多Java软件读写XML都在使用dom4j,Sun公司的JAXM也是用dom4j。Hib...

iborder
2016/10/18
112
0
java的XML解析(DOM4J技术)

DOM4J技术解析XML文件   一,XML简介     xml (可扩展标记语言) 全称: Extended Markup Language     可扩展的含义:允许程序员按照自己的想法去扩展新的标签     注意:但是扩...

osc_ui6dytbk
2019/01/10
7
0

没有更多内容

加载失败,请刷新页面

加载更多

一言难尽,Jpa这个功能差点让我丢了工作

故事背景 前阵子,有位朋友在微信上问我数据被删了能不能恢复,我问了下原因,居然是因为一个配置项惹的祸。 故事细节 在 Spring Boot 中使用 jpa 来操作数据库,jpa 就不做详细的介绍了,相...

osc_axe50nd6
27分钟前
12
0
Link Cut Tree

//知识点 : LCT /*By:Luckyblock*/#include <cstdio>#include <ctype.h>#include <algorithm>#define ls (t[x].son[0])#define rs (t[x].son[1])const int kMaxn = 1e5 + 10;//===......

osc_q5urtsdm
28分钟前
25
0
【问题】Could not locate PropertySource and the fail fast property is set, failing

这是我遇到的问题 Could not locate PropertySource and the fail fast property is set, failing springcloud的其他服务读取不了配置中心得配置文件出错,原因是配置中心的一个配置文件有s...

osc_z9jr2tjo
30分钟前
14
0
Angular SPA基于Ocelot API网关与IdentityServer4的身份认证与授权(四)

在上一讲中,我们已经完成了一个完整的案例,在这个案例中,我们可以通过Angular单页面应用(SPA)进行登录,然后通过后端的Ocelot API网关整合IdentityServer4完成身份认证。在本讲中,我们...

osc_doeya1ck
31分钟前
16
0
[推荐]大量 Blazor 学习资源(一)

前言 / Introduction Blazor 是什么? Blazor 允许您使用 C# 而不是 JavaScript 构建交互式 Web UI。 Blazor 应用由使用 C#、HTML 和 CSS 实现的可重用 Web UI 组件组成。客户端和服务器代码...

osc_3r4js8qy
32分钟前
21
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部