package com.hengtian.util;
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;
public class XmlManager {
public static void main(String[] args) {
XmlManager xmlManager = new XmlManager();
// 初始化xml文档
Document doc = null;
// 通过dom4j方法创建xml
String[] arr = new String[]{"1","2","3","4","5","6","7","8","9"};
doc = xmlManager.createXml(arr);
// 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);
if(!inputXml.exists()){//判断文件是否存在
try {
inputXml.createNewFile(); //创建文件
} catch (IOException e) {
e.printStackTrace();
}
}
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(String[] arr) {
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 rssSourcesElement = doc.addElement("RSSsources");
// 增加注释
// studentsElement.addComment("Students Table");
for(String str : arr){
Element rssElement = rssSourcesElement.addElement("rssSource");
rssElement.addAttribute("sourceId", str);
}
// // 增加子节点
// 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;
}
public Document createXml(List<Long> arr) {
Document doc = DocumentHelper.createDocument();
Map<String, String> inMap = new HashMap<String, String>();
// 增加根节点
Element rssSourcesElement = doc.addElement("Urls");
for(Long str : arr){
Element rssElement = rssSourcesElement.addElement("url");
rssElement.addAttribute("CRC32", str.toString());
}
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.flush();
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());
}
}
}