DOM4J
Dom4j是一个简单、灵活的开放源代码的库。Dom4j是由早期开发JDOM的人分离出来而后独立开发的。与JDOM不同的是,dom4j使用接口和抽象基类,虽然Dom4j的API相对要复杂一些,但它提供了比JDOM更好的灵活性。
Dom4j是一个非常优秀的Java XML API,具有性能优异、功能强大和极易使用的特点。现在很多软件采用的Dom4j,例如Hibernate,包括sun公司自己的JAXM也用了Dom4j。
使用Dom4j开发,需下载dom4j相应的jar文件。
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");
节点对象
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();
在指定位置插入节点
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);
字符串与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解析XML文件
<!-- XML文档 -->
<?xml version="1.0" encoding="UTF-8"?>
<书架>
<书>
<书名>Java</书名>
<作者>刘毅</作者>
</书>
<书>
<书名>C语言</书名>
<作者>刘星</作者>
</书>
</书架>
@Test
public void add() throws Exception {
SAXReader reader = new SAXReader();
Document document = reader.read("src/test/NewFile.xml");
Element book = document.getRootElement().element("书");
List list = book.elements();
// 指定位置添加标签
Element price = DocumentHelper.createElement("售价");
price.setText("50元");
list.add(2, price);
// 格式化输入器
OutputFormat format = OutputFormat.createPrettyPrint();
format.setEncoding("UTF-8");
XMLWriter writer = new XMLWriter(new FileOutputStream("src/test/NewFile.xml"), format);
writer.write(document);
writer.close();
}
@Test
public void delete() throws Exception {
SAXReader reader = new SAXReader();
Document document = reader.read("src/test/NewFile.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/test/NewFile.xml"), format);
writer.write(document);
writer.close();
}
@Test
public void update() throws Exception {
SAXReader reader = new SAXReader();
Document document = reader.read("src/test/NewFile.xml");
Element book = (Element) document.getRootElement().elements("书").get(1);
book.element("作者").setText("二逼青年");
// 格式化输入器
OutputFormat format = OutputFormat.createPrettyPrint();
format.setEncoding("UTF-8");
XMLWriter writer = new XMLWriter(new FileOutputStream("src/test/NewFile.xml"), format);
writer.write(document);
writer.close();
}
@Test
public void read() throws DocumentException {
SAXReader reader = new SAXReader();
Document document = reader.read("src/test/NewFile.xml");
Element root = document.getRootElement();
Element book = (Element) root.elements("书").get(1);
String v1 = book.element("书名").getText();// 获取标签文本
String v2 = book.element("书名").attributeValue("name");// 获取标签属性
System.out.println(v1 + "------" + v2);
}
// XPath技术提取xml文档的数据
@Test
public void newRead() throws DocumentException {
SAXReader reader = new SAXReader();
Document document = reader.read("src/test/NewFile.xml");
String value = document.selectSingleNode("//作者").getText();
System.out.println(value);
}