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() + "》》》》》》"); } }