java项目概览:
XmlManage.java
package com.jialin;
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;
/**
* 测试DOM4J创建,修改,遍历XML
*
* @author jialin
*
*/
public class XmlManager {
public static void main(String[] args) {
XmlManager xmlManager = new XmlManager();
// 初始化xml文档
Document doc = null;
// 通过dom4j方法创建xml
// doc = xmlManager.createXml();
// XML字符串
// String strXMl = "<?xml version=\"1.0\" encoding=\"UTF-8\"?>"
// + "<?xml-stylesheet type=\"text/xsl\" href=\"students.xsl\"?>"
// + "<students><!--Students Table--> <student stu=\"001\">"
// + "<name>张三</name><age>18</age></student><student stu=\"002\">"
// + "<name>李四</name><age>19</age></student></students>";
// 通过字符串创建xml
// doc = xmlManager.createDocumentByString(strXMl);
// XMl输出路径
// String outputPath = "xml/Students.xml";
// 输出xml
// xmlManager.saveDocument(doc, outputPath);
// xml输入路径
String inputPath = "xml/Students.xml";
// 根据xml路径更改XML
//xmlManager.ModifyXml(inputPath);
// 根据xml路径获取doc
doc = xmlManager.getDocument(inputPath);
// 遍历XML
xmlManager.traversalDocumentByElementIterator(doc);
// xmlManager.traversalDocumentByVisitor(doc);
//xmlManager.traversalDocumentByElements(doc);
//xmlManager.traversalDocumentByselectNodes(doc, "/Students/student/name");
}
/**
* 获取XML文件
* @param inputPath
* @return
*/
public Document getDocument(String inputPath) {
// 输入文件
File inputXml = new File(inputPath);
SAXReader saxReader = new SAXReader();
Document document = null;
try {
document = saxReader.read(inputXml);
} catch (DocumentException e) {
e.printStackTrace();
}
return document;
}
/**
* 通过Dom4j方法创建xml文档
*
* @return
*/
public Document createXml() {
Document doc = DocumentHelper.createDocument();
// 创建ProcessingInstruction
Map<String, String> inMap = new HashMap<String, String>();
inMap.put("type", "text/xsl");
inMap.put("href", "students.xsl");
doc.addProcessingInstruction("xml-stylesheet", inMap);
// 增加根节点
Element studentsElement = doc.addElement("Students");
// 增加注释
studentsElement.addComment("Students Table");
// 增加子节点
Element stuElement = studentsElement.addElement("student");
// 增加属性
stuElement.addAttribute("stu", "001");
// 增加名称节点
Element nameElement = stuElement.addElement("name");
// 设置名称节点的值
nameElement.setText("张三");
// 增加年龄节点
Element ageElement = stuElement.addElement("age");
// 设置年龄节点的值
ageElement.setText("18");
// 同上
Element anotherStuElement = studentsElement.addElement("student");
anotherStuElement.addAttribute("stu", "002");
Element anotherNameElement = anotherStuElement.addElement("name");
anotherNameElement.setText("李四");
Element anotherAgeElement = anotherStuElement.addElement("age");
anotherAgeElement.setText("19");
return doc;
}
/**
* 通过字符串创建xml文档
* @param xmlStr
* @return
*/
public Document createDocumentByString(String xmlStr) {
Document doc = null;
try {
// 通过字符串转换直接构建xml文档
doc = DocumentHelper.parseText(xmlStr);
} catch (DocumentException e) {
e.printStackTrace();
}
return doc;
}
/**
* 修改xml
*
* @param inputXmlPath
*/
public void ModifyXml(String inputXmlPath) {
// 获取文件
File inputXml = new File(inputXmlPath);
try {
SAXReader saxReader = new SAXReader();
// 创建document
Document doc = saxReader.read(inputXml);
// 读取Students/student下所有具有属性stu的元素
List list = doc.selectNodes("/Students/student/@stu");
Iterator iter = list.iterator();
while (iter.hasNext()) {
Attribute attribute = (Attribute) iter.next();
if (attribute.getValue().equals("001"))
attribute.setValue("0001");
}
list = doc.selectNodes("/Students/student");
iter = list.iterator();
while (iter.hasNext()) {
Element element = (Element) iter.next();
Iterator iterator = element.elementIterator("name");
while (iterator.hasNext()) {
Element nameElement = (Element) iterator.next();
if (nameElement.getText().equals("张三"))
nameElement.setText("王五");
}
}
String outputPath = "xml/Students-Modified.xml";
saveDocument(doc, outputPath);
}
catch (DocumentException e) {
System.out.println(e.getMessage());
}
}
/**
* 将文档输出到文件保存,可指定格式化输出,可指定字符编码。
*
* @param document
* @param outputFile
*/
public void saveDocument(Document doc, String outputPath) {
// 输出文件
File outputFile = new File(outputPath);
try {
// 美化格式
OutputFormat format = OutputFormat.createPrettyPrint();
// 指定XML编码,不指定的话,默认为UTF-8
format.setEncoding("UTF-8");
XMLWriter output = new XMLWriter(new FileWriter(outputFile), format);
output.write(doc);
output.close();
} catch (IOException e) {
System.out.println(e.getMessage());
}
}
/**
* 普通方法遍历xml
*
* @param doc
*/
public void traversalDocumentByElementIterator(Document doc) {
// 获取根节点
Element root = doc.getRootElement();
// 枚举根节点下所有子节点
for (Iterator ie = root.elementIterator(); ie.hasNext();) {
System.out.println("======");
Element element = (Element) ie.next();
System.out.println(element.getName());
// 枚举属性
for (Iterator ia = element.attributeIterator(); ia.hasNext();) {
Attribute attribute = (Attribute) ia.next();
System.out.println(attribute.getName() + ":"
+ attribute.getData());
}
// 枚举当前节点下所有子节点
for (Iterator ieson = element.elementIterator(); ieson.hasNext();) {
Element elementSon = (Element) ieson.next();
System.out.println(elementSon.getName() + ":"
+ elementSon.getText());
}
}
}
/**
* 使用elements方法进行xml的读取,相当于条件查询,可以根据不同的节点,利用for循环查询该节点下所有的数据。
*
* @throws DocumentException
*/
public static void traversalDocumentByElements(Document doc) {
// 获取根节点
Element root = doc.getRootElement();
// 根据根节点,将根节点下 student中的所有数据放到list容器中。
List list = root.elements("student");
// 这种遍历方式,是jdk1.5以上的版本支持的遍历方式,嘿嘿试试
for (Object obj : list) {
Element el = (Element) obj;
System.out.println("----------"+el.getName()+"-----------");
// 获取name节点下所有的内容,存入listName容器中
List listName = el.elements("name");
// 获取age节点下所有的内容,存入age容器中
List listAge = el.elements("age");
for (int i=0;i<listName.size();i++) {
Element elname = (Element) listName.get(i);
// 获取name节点下的数据。
System.out.println(elname.getName() + ": " + elname.getText());
Element elage = (Element) listAge.get(i);
// 获取age节点下的数据。
System.out.println(elage.getName() + ": " + elage.getText());
}
}
}
/**
* 使用selectNodes读取xml文件
*
* @param args
* @throws DocumentException
*/
public static void traversalDocumentByselectNodes(Document doc,
String elementpath) {
// 使用selectNodes获取所要查询xml的节点。
List list = doc.selectNodes(elementpath);
// 遍历节点,获取节点内数据。
for (Iterator ie = list.iterator(); ie.hasNext();) {
Element el = (Element) ie.next();
System.out.println(el.getName() + ": " + el.getText());
}
}
/**
* 基于访问者模式遍历
*
* @param doc
*/
public void traversalDocumentByVisitor(Document doc) {
doc.accept(new MyVisitor());
}
}
MyVisitor.java
package com.jialin;
import org.dom4j.Attribute;
import org.dom4j.Element;
import org.dom4j.ProcessingInstruction;
import org.dom4j.VisitorSupport;
/**
* 定义自己的访问者类
*/
public class MyVisitor extends VisitorSupport {
/**
* 对于属性节点,打印属性的名字和值
*/
public void visit(Attribute node) {
System.out.println("attribute : " + node.getName() + " = "
+ node.getValue());
}
/**
* 对于处理指令节点,打印处理指令目标和数据
*/
public void visit(ProcessingInstruction node) {
System.out.println("PI : " + node.getTarget() + " "
+ node.getText());
}
/**
* 对于元素节点
* 如果包含文本内容,则打印元素的名字和元素的内容。如果不是,则只打印元素的名字
*/
public void visit(Element node) {
if (node.isTextOnly())
System.out.println("element : " + node.getName() + " = "
+ node.getText());
else
System.out.println("《《《《《《" + node.getName() + "》》》》》》");
}
}