DOM4J解析XML文件是DOM解析中最好用的一种方法,只要在工程目录下导入dom4j-1.6.1.jar就行了
package cn.moving.parseXml;
import java.io.File;
import java.io.FileOutputStream;
import java.util.List;
import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;
import org.junit.Test;
public class Dom4jParse {
@Test
public void read() throws Exception {
SAXReader reader = new SAXReader();
Document document = reader.read(new File(
"src/cn/moving/parseXml/book.xml"));
Element books = document.getRootElement();
Element e = (Element) books.elements().get(0);
Element bookName = e.element("书名");
System.out.println(bookName.getText());
Attribute attr = bookName.attribute("name");
System.out.println(attr.getText());
}
@Test
public void add() throws Exception {
SAXReader reader = new SAXReader();
Document document = reader.read("src/cn/moving/parseXml/book.xml");
Element book = (Element) document.getRootElement().element("书");
book.addElement("出版社").setText("人民邮电出版社");
OutputFormat format = OutputFormat.createCompactFormat();
// OutputFormat format = new OutputFormat();
format.setEncoding("UTF-8");
XMLWriter writer = new XMLWriter(new FileOutputStream(
"src/cn/moving/parseXml/outbook2.xml"));
// XMLWriter writer = new XMLWriter(new
// FileOutputStream("src/cn/moving/parseXml/outbook2.xml"), format);
writer.write(document);
writer.close();
}
@Test
//往指定位置添加元素
public void addAppoint() throws Exception {
SAXReader reader = new SAXReader();
Document document = reader.read("src/cn/moving/parseXml/book.xml");
Element book = (Element) document.getRootElement().element("书");
List list = book.elements();//[书名,作者,价格]
Element e = DocumentHelper.createElement("折扣");
e.setText("7折");
list.add(2,e);
OutputFormat format = OutputFormat.createCompactFormat();
// OutputFormat format = new OutputFormat();
format.setEncoding("UTF-8");
XMLWriter writer = new XMLWriter(new FileOutputStream(
"src/cn/moving/parseXml/outbook2.xml"));
//漂亮格式输出
// XMLWriter writer = new XMLWriter(new FileOutputStream("src/cn/moving/parseXml/outbook2.xml"), format);
writer.write(document);
writer.close();
}
@Test
// 删除节点<售价>10</售价>
public void delete() throws Exception {
SAXReader reader = new SAXReader();
Document document = reader.read("src/cn/moving/parseXml/book.xml");
Element element = document.getRootElement().element("书").element("售价");
element.getParent().remove(element);
XMLWriter writer = new XMLWriter(new FileOutputStream("src/cn/moving/parseXml/book.xml"));
writer.write(document);
writer.close();
}
@Test
// 更新售价
public void update() throws Exception {
SAXReader reader = new SAXReader();
Document document = reader.read("src/cn/moving/parseXml/book.xml");
Element element = document.getRootElement().element("书").element("售价");
element.setText("59");
XMLWriter writer = new XMLWriter(new FileOutputStream("src/cn/moving/parseXml/book.xml"));
writer.write(document);
writer.close();
}
@Test
//Powerful Navigation with XPath
public void xpath() throws Exception{
SAXReader reader = new SAXReader();
Document document = reader.read(new File("src/cn/moving/parseXml/book.xml"));
String value = document.selectSingleNode("//作者").getText();
Node node = document.selectSingleNode("//书名[@aa='bbb']");
String bookName = document.selectSingleNode("//书名[@aa='bbb']").getText();
String attrValue = node.valueOf("@aa");
System.out.println(value);
System.out.println(attrValue);
System.out.println(bookName);
}
}
使用DOM4J解析与操作XML文件
34万+

被折叠的 条评论
为什么被折叠?



