Dom4j是一个简单、灵活的开放源代码的库。Dom4j是由早期开发JDOM的人分离出来而后独立开发的。与JDOM不同的是,dom4j使用接口和抽象基类,虽然Dom4j的API相对要复杂一些,但它提供了比JDOM更好的灵活性。
Dom4j是一个非常优秀的Java XML API,具有性能优异、功能强大和极易使用的特点。现在很多软件采用的Dom4j,例如Hibernate,包括sun公司自己的JAXM也用了Dom4j。 使用Dom4j开发,需下载dom4j相应的jar文件。
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");
节点对象:
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());
节点对象属性:
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");
将文档写入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(new FileOutputStream ("output.xml"),format);
writer.write(document);
writer.close();
Dom4j在指定位置插入节点
1.得到插入位置的节点列表(list)
2.调用list.add(index,elemnent),由index决定element的插入位置。
Element元素可以通过DocumentHelper对象得到。
示例代码:
Element aaa = DocumentHelper.createElement("aaa");
aaa.setText("aaa"); List list = root.element("书").elements();
list.add(1, aaa);
实例:
1 package com.cskaoyan.dom4j; 2 3 import java.io.FileOutputStream; 4 import java.io.FileWriter; 5 6 import org.dom4j.Document; 7 import org.dom4j.DocumentException; 8 import org.dom4j.Element; 9 import org.dom4j.io.OutputFormat; 10 import org.dom4j.io.SAXReader; 11 import org.dom4j.io.XMLWriter; 12 13 public class Dom4jDeom { 14 15 /** 16 * @param args 17 * @throws Exception 18 */ 19 public static void main(String[] args) throws Exception { 20 // TODO Auto-generated method stub 21 22 //增 23 //删 24 //改 25 //查 26 27 //查找第二本书的价格: 28 //第一步,解析xml文件,获取解析后的document对象; 29 /* SAXReader reader = new SAXReader(); 30 Document document = reader.read("src/books.xml"); 31 //第二部,获取根节点信息 32 Element root = document.getRootElement(); 33 //第三步,获取对应节点,应得到想要的信息 34 Element book1 = (Element) root.elements().get(1); 35 Element price = (Element) book1.element("author"); 36 // System.out.println( price.getText()); 37 book1.remove(price);*/ 38 52 //增 53 /*SAXReader reader = new SAXReader(); 54 Document document = reader.read("src/books.xml"); 55 Element root = document.getRootElement(); 56 Element book1 = (Element) root.elements().get(1); 57 Element author = book1.addElement("author"); 58 author.setText("李开复"); 59 60 OutputFormat format = OutputFormat.createPrettyPrint();// 指定XML编码 61 format.setEncoding("utf-8"); 62 XMLWriter writer = new XMLWriter(new FileOutputStream ("src/books.xml"),format); 63 writer.write(document); 64 writer.close();*/ 65 66 //改 67 /*SAXReader reader = new SAXReader(); 68 Document document = reader.read("src/books.xml"); 69 Element root = document.getRootElement(); 70 Element book1 = (Element) root.elements().get(1); 71 Element author = (Element) book1.element("author"); 72 author.setText("吴军"); 73 74 OutputFormat format = OutputFormat.createPrettyPrint();// 指定XML编码 75 format.setEncoding("utf-8"); 76 XMLWriter writer = new XMLWriter(new FileOutputStream ("src/books.xml"),format); 77 writer.write(document); 78 writer.close();*/ 79 80 81 // XPATH 82 83 SAXReader reader = new SAXReader(); 84 Document document = reader.read("src/books.xml"); 85 86 Element priceElement = (Element) document.selectNodes("books/book/*").get(3); 87 88 System.out.println( priceElement.getText()); 89 90 //第三步,获取对应节点,应得到想要的信息 91 /*Element book1 = (Element) root.elements().get(1); 92 Element price = (Element) book1.element("author");*/ 93 // System.out.println( price.getText()); 94 95 //使用xpath 去实现节点的增删改查操作! 96 97 98 } 99 100 }