DOM4J由dom4j.org出品的一个开源XML解析包,是一个易用的、开源的库,用于XML。它应用于Java平台,采用了Java集合框架并完全支持DOM,SAX和JAXP。Dom4j是目前最流行、最好用的XML解析工具,解析XML的速度最快。
例1:利用dom4j相关API在d盘生成一个xml文件
前期准备:在项目中导入 dom4j-1.6.1.jar
package com.xzy;
import java.io.FileOutputStream;
import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.XMLWriter;
/**
* 利用dom4j相关API在d盘生成一个xml文件
* @author ASUS
*/
public class Demo01 {
public static void main(String[] args) throws Exception
{
//区分dom4j的org.dom4j.document和 org.w3c.Document
//我们在内存中创建了dom4j的内存树
Document doc=DocumentHelper.createDocument();
//创建根节点
Element root=DocumentHelper.createElement("stus");
root.addAttribute("aa", "bbb");//设置根节点属性
doc.setRootElement(root);
//设置子元素及元素内容
Element stu=root.addElement("stu");
stu.addAttribute("sn", "001");
Element name=stu.addElement("name");
name.setText("李四");
//对生成的文件格式进行美化
OutputFormat outFmt=OutputFormat.createPrettyPrint();
outFmt.setEncoding("utf-8");
outFmt.setIndent(" ");
//将dom4j生成的树,输出到文档
XMLWriter xmlWriter=new XMLWriter(new FileOutputStream("d:\\hi.xml"),outFmt);
xmlWriter.write(doc);
System.out.println("Ok");
}
}
例2:利用DOMReader和SAXReader构造dom4j树
dom4j在org.dom4j.io包中,提供了两个类DOMReader和SAXReader,DOMReader从一个现有的W3C DOM树构建dom4j树,而SAXReader则使用SAX解析器,从不同的输入源来构造dom4j树。
package com.xzy;
import java.io.File;
import java.util.List;
import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
/**
* 构建org.dom4j.Document
* @author Administrator
*
*/
public class Demo02 {
public static void main(String[] args)throws Exception {
//以DOMReader类构造dom4j文档对象
/*DocumentBuilderFactory dbf=DocumentBuilderFactory.newInstance();
DocumentBuilder db=dbf.newDocumentBuilder();
File f=new File("c:\\students.xml");
org.w3c.dom.Document wdoc=db.parse(f);
DOMReader domReader=new DOMReader();
org.dom4j.Document doc=domReader.read(wdoc);
*/
//以SAXReader类来构造dom4j文档对象
SAXReader saxReader=new SAXReader();
File file=new File("d:\\students.xml");
Document doc=saxReader.read(file);
//构建dom4j文档树完成,接下来就可以使用 dom4japi了!
//访问根元素
Element root=doc.getRootElement();
//删除根元素下的某个元素
Element eltStru=root.element("stu");
root.remove(eltStru);
//访问根元素下的节点
List<Element> subs=root.elements();
for(Element sub:subs)
{
System.out.println(sub.getName()+"---"+sub.getStringValue());
}
//访问属性
Element elt=root.element("stu");
String attrValue=elt.attributeValue("sn");
System.out.println(attrValue);
}
}