DOM4J总结:
DOM4J
解析XML
文档:
• 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 = "";
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(newFileWriter("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);
//更新document
代码:
①
//
在指定位置修改
public static void update()throws Exception{
/*
* 1、解析xml文档,将xml文档转换Dom4j树
* 2、利用dom4j树提供的导航方法找到需要修改的节点
* 3、修改指定的节点,或者在指定的节点添加新的节点
* 4、写入到dom4j树document中,写入修改后的xml文件中
* */
SAXReader reader = new SAXReader();
Document doc = reader.read(new File("src//bk.xml"));
Element root = doc.getRootElement();
Element book2 = (Element)root.elements("book").get(1);
List list = book2.elements();
Element address = DocumentHelper.createElement("address");
address.setText("保定");
list.add(2,address);
OutputFormat format = new OutputFormat(" ",true,"UTF-8");
XMLWriter xw = new XMLWriter(new FileWriter("src//bk.xml"),format);
xw.write(doc);
xw.close();
}
//Bk.xml
文件
name文本1
name文本2
name文本3
name文本4
②
//
利用dom4j
来创建xml
文档
public class Demo02 {
public static void main(String[] args)throws Exception {
//documentHelper的createDocument()方法创建document对象
Document doc = DocumentHelper.createDocument();
//或者是用DocumentFactory来创建
/*DocumentFactory df = new DocumentFactory();
Document doc1 = df.createDocument();*/
Element root = doc.addElement("books");
//添加四个元素
Element book = root.addElement("book");
book.addAttribute("isbn", "10001");
Element name = book.addElement("name");
name.setText("name
文本");
Element author = book.addElement("author");
author.setText("author 文本");
Element price = book.addElement("price");
price.setText("100");
OutputFormat format = new OutputFormat(" ",true,"UTF-8");
XMLWriter xw = new XMLWriter(new FileWriter("src//bk.xml"),format);
xw.write(doc);
xw.close();
}
}
③
//
使用dom4j
解析xml
文档
解析元素
解析元素的文本
解析元素属性
public class Demo01 {
public static void main(String[] args) throws Exception {
//
读取器
SAXReader reader = new SAXReader();
// 读取xml文档 解析xml文档
Document doc = reader.read(new File("src//book.xml"));
// 获取根据节点
Element root = doc.getRootElement();
System.out.println(root.getName());
parse(root);
}
/*
* //解析元素 public static void parse(Element root){ parseAttr(root);
* List list = root.elements(); for(Element entity :list){
* //判读是否只有文本 if(entity.isTextOnly()){ parseAttr(entity);
* System.out.println(entity.getText()); }else{ parse(entity); } } }
* //解析元素的属性 private static void parseAttr(Element root) {
* List attrs = root.attributes();
* System.out.println(attrs.size()); for(Attribute entity :attrs){
* System.out.println(entity.getName()+"--------------"+entity.getValue());
* }
* }
*/
// 解析元素
public static void parse(Element root) {
parseAttr(root);
for (Iterator it = root.elementIterator(); it.hasNext();) {
Element entity = it.next();
// 判断是否只是文本
if (entity.isTextOnly()) {
parseAttr(entity);
System.out.println(entity.getText());
} else {
parse(entity);
}
}
}
// 解析元素的属性
private static void parseAttr(Element root) {
for (Iterator it = root.attributeIterator(); it.hasNext();) {
Attribute entity = it.next();
System.out.println(entity.getName() + "--------------"
+ entity.getValue());
}
}
}