xml之dom4j解析

* 使用dom4j解析xml 实例在java520里面 TextDom4j
* dom4j,是一个组织,针对xml解析,提供解析器dom4j
* dom4j不是javase的一部分,想要使用第一步需要怎么做
- 导入dom4j提供jar包
- 常见一个文件夹lib
- 复制jar包到lib下面
- 邮件点击jar包.builb path -- add to bulildpath
- 看到jar包变成奶瓶装 表示导入成功
* 得到document使用
* SAXReader reader = new SAXReader();
Document document = reader.read(url);
* document父节点是node找不到方法去弄得中去找.

*document里面的方法getRootElement():获取根节点,返回的是Element
*Element也是一个接口
- Element和Node里面的方法
** getParent():获取父节点
** addElement:获取标签
** element(qname);获取p1下面所有叫qname的一个标签
** elements(qname)获取p1下面的所有qname标签
** elements();获取下面所有标签
* 使用dom4j查询元素;
* 查询所有那么元素里面的值
/*
创建解析器
得到document
得到根节点
得到 多有p1标签

得到name
得到name里面的值
*/
//得到document
SAXReader saxReader = new SAXReader();
Document document = saxReader.read("E:/java520/TextDom4j/src/cn/Dom4j/1.xml");
//得到root节点
Element root = document.getRootElement();
//获取p1
@SuppressWarnings("unchecked")
List<Element> list = root.elements("p1");
//遍历函数
for (Element element1 : list) {
Element name = element1.element("name");
String str = name.getText();
System.out.println(str);
}

* 使用dom4j添加标签,如添加<sex>中国</sex>
//利用sax得到document
SAXReader reader = new SAXReader();
Document doc = reader.read("E:/java520/TextDom4j/src/cn/Dom4j/1.xml");
//得到根节点
Element root = doc.getRootElement();
//得到第一个p1
Element p = root.element("p1");
//在p1下边添加元素
Element xin = p.addElement("sex");
//在xin下面添加文本
xin.setText("中国");

//回写xml
OutputFormat format = OutputFormat.createPrettyPrint();//漂亮的格式
XMLWriter xml = new XMLWriter(new FileOutputStream("E:/java520/TextDom4j/src/cn/Dom4j/1.xml"), format);//利用写入流将文件写入到doc中
xml.write(doc);//再将doc中文件写入源文件中
xml.close();//关流
* 在特定的文值添加元素:入在第一个p1下面的age标签之前添加<school>学校</school>
* 创建解析器
* 得到document
* 得到根节点
* 获取第一个p1
* 获取p1下面的所有元素
** elements()方法,返回list集合
** 使用list里面的方法.在特定位置添加元素
** 创建元素 documentHelper.createElement("school");
*** add(int index,E element0
- 第一个参数是文职下标,从0开始
- 一二个参数是要添加的元素
* 回写xml
public static void tianjia() throws Exception {
//利用sax获取document文件
SAXReader reader = new SAXReader();
Document document = reader.read("E:/java520/TextDom4j/src/cn/Dom4j/1.xml");
//获取root节点
Element root = document.getRootElement();
//得到第一个p1
List<Element> p1 = root.elements();
//创建元素
Element school = DocumentHelper.createElement("school");
//给school创建文本
school.setText("学校");
//利用javase中的list添加方法添加
p1.add(1, school);
//回写xml
OutputFormat format = OutputFormat.createPrettyPrint();
XMLWriter xmlWriter = new XMLWriter(new FileOutputStream("E:/java520/TextDom4j/src/cn/Dom4j/1.xml"), format);
xmlWriter.write(document);
xmlWriter.close();

* 使用dom4j修改
* 创建解析器
* 得到document
* 得到根节点
* 获取第一个p1
* 获取p1下面的要修改的元素
*.element("**")
* 修改 使用setText("修改后的内容")方法
* 回写xml
* 使用dom4j实现删除节点的操作
* 创建解析器
* 得到document
* 得到根节点
* 获取第一个p1
* 获取p1下面的要修改的元素
*.element("**")
* 利用父节点删除节点
* 获取父节点 *.getParent();
* *.remover(*);
* 回写xml
* 使用dom4j获取属性的操作
* 得到document
* 得到根节点
* 得到第一个p1元素
* 得到p1里面的属性值
- String value = p1.attributeValue("id1");

* 使用dom4j支持xpath的操作
* 可以直接取到某个元素
1. /AAA/DDD/BBB: 表示一层一层的AAA下面的DDD下面的BBB
2. //BBB: 表示和这个名称相同,只要是名称为BBB的都得到:
3. /*: 表示所有的都得到:
4. BBB[1]:表示BBB第一个元素:
BBB[last()]:表示BBB最后一个元素
5. //BBB[@id]: 表示只要BBB上边有id属性的都得到
6. //BBB[@id="b1"]: 表示元素名称是BBB,在BBB上面所有属性id,并且id的属性值为b1;
* 使用dom4j支持xpath的具体操作
** 默认的情况下,dom4j不支持xpath
** 如果想要zaidom4j里面使用xpath
* 第一步需要引入xpath的jar包;dom4j-1.6.1/lib/jaxen-1.1-beta-6.jar包
** 在dom4j里面提供了两个方法啊,用来支持xpath
* selectNodes("xpath表达式")
- 获取多个节点
* selectSingleNode("xpath表达式")
- 获取单一节点
/*
/**
* 得到document
* 使用selectNode("xpath")方法得到name
*/
Document document = Dom4jutils.getDocument(Dom4jutils.PATH);
List<Node> list = document.selectNodes("//name");
for (Node node : list) {
String str = node.getText();
System.out.println(str);
}
*/
* 使用xpath实现:获取第一个p1下面的name值
* //p1[@id1=‘aaa‘]/name
* 使用到selectSingleNode("//p1[@id1=‘aaa‘]/name")
**方法步骤
/**
* 得到document
* 利用xpath的到p1下面的值
* */
Document document = Dom4jutils.getDocument(Dom4jutils.PATH);
Node name = document.selectSingleNode("//p1[@id=‘aaa‘]/name");
String str = name.getText();
System.out.println(str);
* 实现简单的学生管理系统;
* 使用xml当做数据,存储学生信息:
* 创建xml文件,做学生信息:

时间: 2024-11-05 18:45:21

xml之dom4j解析的相关文章

XML(四)dom4j解析XML

使用dom4j需要导入jar包 jar包下载地址:http://pan.baidu.com/s/1o65jWRw 将dom4j-1.6.1.jar包导入Eclipse book2.xml <?xml version="1.0" encoding="UTF-8"?> <书架> <书> <书名>JAVA</书名> <作者>XXXXXX</作者> <售价>23333</售

dom4j解析Xml,dom4j解析带命名空间的Xml内容,dom4j解析xml为实体类

首先引入maven: <dependency> <groupId>dom4j</groupId> <artifactId>dom4j</artifactId> <version>1.6.1</version> </dependency> <dependency> <groupId>jaxen</groupId> <artifactId>jaxen</arti

【java项目实战】dom4j解析xml文件,连接Oracle数据库

简介 dom4j是由dom4j.org出品的一个开源XML解析包.这句话太官方,我们还是看一下官方给出的解释.如下图: dom4j是一个易于使用的.开源的,用于解析XML,XPath和XSLT等语言的库.它应用于Java平台,采用了Java集合框架并完全支持DOM,SAX和JAXP等编程标准. 特点 dom4j是一个非常非常优秀的Java XML API,具有性能优异.功能强大和极端易用的特点,同时它也是一个开放源代码的软件.如今你可以看到越来越多的Java软件都在使用dom4j来读写XML,例

xml(3)--dom4j实现crud操作

1.XML解析技术概述 (1)XML解析方式分为两种:dom和sax dom:(Document Object Model, 即文档对象模型) 是 W3C 组织推荐的处理 XML 的一种标准方式. sax: (Simple API for XML) 不是官方标准,但它是 XML 社区事实上的标准,几乎所有的 XML 解析器都支持它. (2)XML解析器(软件/实现类) Crimson(SUN).Xerces(IBM->APACHE) .Aelfred2(DOM4J开源组织) (3)XML解析技术

【收藏用】--切勿转载JAVA 使用Dom4j 解析XML

原帖地址 : http://blog.csdn.NET/yyywyr/article/details/38359049 解析XML的方式有很多,本文介绍使用dom4j解析xml. 1.环境准备 (1)下载dom4j-1.6.1.jar (2)下载junit-4.10.jar 2.温馨提示 解析XML过程是通过获取Document对象,然后继续获取各个节点以及属性等操作,因此获取Document对象是第一步,大体说来,有三种方式: (1)自己创建Document对象   Document docu

转:在java中使用dom4j解析xml

在java中使用dom4j解析xml 虽然Java中已经有了Dom和Sax这两种标准解析方式 但其操作起来并不轻松,对于我这么一个初学者来说,其中部分代码是活生生的恶心 为此,伟大的第三方开发组开发出了Jdom和Dom4j等工具 鉴于目前的趋势,我们这里来讲讲Dom4j的基本用法,不涉及递归等复杂操作 Dom4j的用法很多,官网上的示例有那么点儿晦涩,这里就不写了 首先我们需要出创建一个xml文档,然后才能对其解析 xml文档: <?xml version="1.0" encod

JavaEE XML DOM4J解析

DOM4J解析 @author ixenos DOM4J常用API SAXReader reader = new SAXReader(); //Document对象也看成根节点 Document doc = reader.read(File file); //迭代当前节点下的子节点/也可foreach Iterator itr = doc.nodeIterator(); While(itr.hasNext()){ Node node = itr.next(); } //得到根节点 Element

使用DOM4J解析XMl文件与读取XML文件

XML文件 1 <?xml version="1.0" encoding="UTF-8"?> 2 <bookstore> 3 <book id="1"> 4 <name>冰与火之歌</name> 5 <author>乔治马丁</author> 6 <year>2014</year> 7 <price>89</price&g

DOM4J解析XML

Java中对XML进行解析的方式常见的为四种:SAX,DOM,JDOM,DOM4J     SAX分析器在对XML文档进行分析时,触发一系列的事件,应用程序通过事件处理函数实现对XML文档的访问.由于事件触发本身是有时序性的,因此,SAX分析器提供的是一种对XML文档的顺序访问机制,对于已经分析过的部分,不能再倒回去重新处理. SAX之所以被叫做"简单"应用程序接口,是因为SAX分析器只做了一些简单的工作,大部分工作还要由应用程序自己去做.也就是说,SAX分析器在实现时,它只是顺序地检