books.xml
<?xml version="1.0" encoding="UTF-8"?>
<books>
<book>
<title>Dom4j Tutorials</title>
</book>
<book>
<title>Lucene Studing</title>
</book>
<book>
<title>Lucene in Action</title>
</book>
<owner>O'Reilly</owner>
</books>
package com.hy.dao;
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.util.Iterator;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
public class dom4j {
BufferedWriter bw = null;
public void printXML(String filepath) throws IOException {
bw = new BufferedWriter(new FileWriter(filepath)); // 写文件位置
bw.write("<?xml version='1.0' encoding='GB2312'?>");
try {
SAXReader sreader = new SAXReader();//
File file = new File("");//
Document document = sreader.read(new File(file.getAbsolutePath()
+ "//webRoot//books.xml")); // 读取文件
Element root = document.getRootElement(); // 获得文件的根节点元素
printtree(root, 0);
} catch (Exception e) {
e.printStackTrace();
}
}
public void printtree(Element node, int i) throws IOException {
bw.write("<"); // 打印一个节点开始"<"
String name = node.getName(); // 得到根节点名
bw.write(name); // 打印节点的名字
bw.write(" >"); // 打印节点的结束">";
if (!"".equals(node.getText())) { // 判断是不是有文本值
bw.write(node.getText());
}
// 此处开始递归调用
Iterator ite = node.elementIterator(); // 迭代根元素下面的所有子节点
while (ite.hasNext()) { // 判断是否有下一个元素
Element snode = (Element) ite.next();
printtree(snode, i + 2);
}
bw.write("</" + name + ">");
bw.flush();
}
}
test.java
package com.hy.dao;
import java.io.IOException;
public class test {
public static void main(String[] argv) throws IOException {
String filepath = "E:/dom4j.txt"; //写入的文件路径
dom4j ptree = new dom4j();
ptree.printXML(filepath);
}
}