`
新密牛哥哥
  • 浏览: 1170 次
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

xml的crud

 
阅读更多

XML编程(CRUD)-dom4j-(dom,sax)解析

一.XML编程(CRUD)
1.Tip:XML解析技术概述
XML解析方式分为两种:dom和sax
dom:(Document Object Model, 即文档对象模型) 是 W3C 组织推荐的处理 XML 的一种方式。
sax: (Simple API for XML) 不是官方标准,但它是 XML 社区事实上的标准,几乎所有的 XML 解析器都支持它。
XML解析器
Crimson、Xerces 、Aelfred2
XML解析开发包
Jaxp(sun)、Jdom、dom4j

 

二.Tip:DOM4J解析XML文档
Dom4j是一个简单、灵活的开放源代码的库。Dom4j是由早期开发JDOM的人分离出来而后独立开发的。与JDOM不同的是,dom4j使用接口和抽象基类,虽然Dom4j的API相对要复杂一些,但它提供了比JDOM更好的灵活性。
Dom4j是一个非常优秀的Java XML API,具有性能优异、功能强大和极易使用的特点。现在很多软件采用的Dom4j,例如Hibernate,包括sun公司自己的JAXM也用了Dom4j。
使用Dom4j开发,需下载dom4j相应的jar文件。
*Tip:Document对象
DOM4j中,获得Document对象的方式有三种:

1.读取XML文件,获得document对象
SAXReader reader = new SAXReader();

Document document = reader.read(new File("input.xml"));

2.解析XML形式的文本,得到document对象.
String text = "<members></members>";

Document document = DocumentHelper.parseText(text);

3.主动创建document对象.
Document document = DocumentHelper.createDocument(); //创建根节点
Element root = document.addElement("members");
三.Tip:节点对象
1.获取文档的根节点.
Element root = document.getRootElement();

2.取得某个节点的子节点.
Element element=node.element(“书名");

3.取得节点的文字
String text=node.getText();

4.取得某节点下所有名为“member”的子节点,并进行遍历.

List nodes = rootElm.elements("member");

for (Iterator it = nodes.iterator(); it.hasNext();) {

Element elm = (Element) it.next();

// do something

}

5.对某节点下的所有子节点进行遍历.

for(Iterator it=root.elementIterator();it.hasNext();){

Element element = (Element) it.next();

// do something

}

6.在某节点下添加子节点.

Element ageElm = newMemberElm.addElement("age");
7.设置节点文字.

element.setText("29");

8.删除某节点.

//childElm是待删除的节点,parentElm是其父节点
parentElm.remove(childElm);
9.添加一个CDATA节点.

Element contentElm = infoElm.addElement("content");

contentElm.addCDATA(diary.getContent());

四.Tip:节点对象属性
1.取得某节点下的某属性

Element root=document.getRootElement(); //属性名name
Attribute attribute=root.attribute("size");
2.取得属性的文字

String text=attribute.getText();

3.删除某属性

Attribute attribute=root.attribute("size");

root.remove(attribute);
4.遍历某节点的所有属性

Element root=document.getRootElement();

for(Iterator it=root.attributeIterator();it.hasNext();){

Attribute attribute = (Attribute) it.next();

String text=attribute.getText();

System.out.println(text);

}

5.设置某节点的属性和文字.

newMemberElm.addAttribute("name", "sitinspring");

6.设置属性的文字

Attribute attribute=root.attribute("name");

attribute.setText("sitinspring");

五.Tip:将文档写入XML文件
1.文档中全为英文,不设置编码,直接写入的形式.

XMLWriter writer = new XMLWriter(new FileWriter("output.xml"));

writer.write(document); writer.close();

2.文档中含有中文,设置编码格式写入的形式.

OutputFormat format = OutputFormat.createPrettyPrint();// 指定XML编码
format.setEncoding("GBK");

XMLWriter writer = new XMLWriter(newFileWriter("output.xml"),format);

writer.write(document);writer.close();

六.Tip:Dom4j在指定位置插入节点
1.得到插入位置的节点列表

(list)
2.调用list.add(index,elemnent),由index决定element的插入位置。
Element元素可以通过DocumentHelper对象得到。示例代码:

Element aaa = DocumentHelper.createElement_x_x("aaa");
aaa.setText("aaa");

List list = root.element("书").elements();
list.add(1, aaa);

//更新document

七.Tip:字符串与XML的转换
1.将字符串转化为XML
String text = "<members> <member>sitinspring</member></members>";

Document document = DocumentHelper.parseText(text);

2.将文档或节点的XML转化为字符串.
SAXReader reader = new SAXReader();

Document document = reader.read(new File("input.xml"));

Element root=document.getRootElement();
String docXmlText=document.asXML();
String rootXmlText=root.asXML();

Element memberElm=root.element("member");

String memberXmlText=memberElm.asXML();

八.实例Dom4j的操作

 

//dom4j的CRUD

package cn.itcast.dom4j;

import java.io.File;
import java.io.FileNotFoundException;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.junit.Test;

 


public class Demo1 {

//遍历xml文档

@Test
public void test1() throws DocumentException{
//创建一个SAX阅读器
SAXReader reader = new SAXReader();
//读取xml文档,获得该文档
Document document =reader.read(new File("src/book.xml"));
//调用遍历方法,传入要遍历的文档中的跟节点
list(document.getRootElement());
}

//创建遍历跟节点的方法
private void list(Element rootElement) {
//先获得根节点名
System.out.println(rootElement.getName());
//获得根节点的所有子节点,装入一个集合
List<Node> list =rootElement.elements();
//遍历集合,判断是否有节点,如果是节点再调用遍历方法
for(Node node : list){
if(node instanceof Element){
list((Element)node);
}
}
}

//读取售价的值
@Test
public void read() throws Exception{
//1.获得读取器和文档
SAXReader reader = new SAXReader();
Document document = reader.read(new File("src/book.xml"));
//2.获得根节点
Element root =document.getRootElement();
//3.获得想要得到的值
String author = root.element("书").element("作者").getText();
System.out.println(author);
}

//向xml文档中添加一个:<售价>39元</售价>
@Test
public void write() throws DocumentException, IOException{
//创建读取器
SAXReader reader = new SAXReader();
//读取文档
Document document =reader.read(new File("src/book.xml"));
//创建要添加的节点,利用dom4j的帮助类
Element price = DocumentHelper.createElement_x_x("售价");
price.setText("100元");
//获得根节点
Element root = document.getRootElement();
//找到要插入的节点的父类调用插入方法
root.element("书").add(price);

//创建一个写入编译器
OutputFormat format = OutputFormat.createPrettyPrint();
//设置编译码表
format.setEncoding("UTF-8");
//创建一个XML写入器
XMLWriter writer = new XMLWriter(new FileOutputStream("src/book.xml"),format);
//写入节点
writer.write(document);
writer.close();
}

//向指定位置插入:<售价>39元</售价>
@Test
public void write2() throws DocumentException, IOException{
//获得读取器和文档
SAXReader reader = new SAXReader();
Document document = reader.read(new File("src/book.xml"));
//创建节点和属性
Element price =DocumentHelper.createElement_x_x("售价");
price.setText("39元");
//获得根节点再获得到要插入的父节点
Element book = document.getRootElement().element("书");
//获得对象的所有节点集合
List books = book.elements();
//插入到指定的集合中的位置
books.add(3, price);

//将内存中的写入到xml
OutputFormat format = OutputFormat.createPrettyPrint();
format.setEncoding("UTF-8");
XMLWriter writer = new XMLWriter(new FileOutputStream("src/book.xml"),format);
writer.write(document);
writer.close();
}

//删除售价节点:
@Test
public void delete() throws DocumentException, IOException{
SAXReader reader = new SAXReader();
Document document = reader.read(new File("src/book.xml"));

//获得要删除的节点
Element price = document.getRootElement().element("书").element("售价");
//获取该节点的父节点删除该节点
price.getParent().remove(price);

OutputFormat format = OutputFormat.createPrettyPrint();
format.setEncoding("UTF-8");
XMLWriter writer = new XMLWriter(new FileOutputStream("src/book.xml"),format);
writer.write(document);
writer.close();

}

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics