java解析(操作)XML文件之DOM解析

package com.jonw.dao;

import java.io.File;
import java.io.IOException;
import java.io.Writer;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerConfigurationException;
import javax.xml.transform.TransformerException;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
import javax.xml.xpath.XPath;
import javax.xml.xpath.XPathConstants;
import javax.xml.xpath.XPathExpression;
import javax.xml.xpath.XPathExpressionException;
import javax.xml.xpath.XPathFactory;

import org.dom4j.io.OutputFormat;
import org.dom4j.io.XMLWriter;
import org.w3c.dom.Document;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;

public class PraseXML {
private static String filename = null;// 文件名
private static DocumentBuilderFactory fac = null;
private static DocumentBuilder bu = null;
private static Document doc;// 文档模型
private static XPath xml = null;
private static TransformerFactory tff = null;//文檔轉鐵器
private static Transformer tf = null;
private static DOMSource dom = null;
private static StreamResult sr = null;
private static PraseXML InstancesPraseXML = null;// 單例

/**
* 初始化成員變量
*/
private PraseXML() {
this.filename = new String(PraseXMLStatic.PATH);
beforePraseXML();
}

/**
* 單例此對象的一個實例
*
* @return PraseXML
*/
public static PraseXML getInstancesPraseXML() {
if (InstancesPraseXML == null)
return new PraseXML();
return InstancesPraseXML;
}

/**
* 返回name的所有結點
*
* @param name
* @return NodeList
*/
public NodeList getObjectInstances(String name) {
try {
XPathExpression exp = xml.compile("//"+name);//匹配所有的Service結點
Object obj = exp.evaluate(doc, XPathConstants.NODESET);
NodeList list = (NodeList) obj;

for (int i = 0; i < list.getLength(); i++) {
System.out.println(list.item(i).getAttributes().getNamedItem(
"name").getNodeValue());//輸出Serive結點的屬性
list.item(i).getAttributes().getNamedItem("name").setNodeValue(
"jonw");//修改Service結點的屬性

}

this.afterPraseXML();//善後處理
return list;//近回所有的Service結點
} catch (Exception e) {
System.out.println("*****************");
return null;
}

}

/**
* 在进行所有增删改查的操作前的准备工作
*/
private void beforePraseXML() {
try {
fac = DocumentBuilderFactory.newInstance();//獲得一個XML文檔解析器
bu = fac.newDocumentBuilder();//解析XML文件得到一個DOM文檔類接口,以便訪問DOM
doc = bu.parse("src/server.xml");//初始化DOCUMENT對象
xml = XPathFactory.newInstance().newXPath();//創建一個XPATH對象

} catch (Exception e) {
System.out.println("實例化XML文件失敗");
}
}

/**
* 在进行所有增删改查的操作后的善后处理
*/
public void afterPraseXML() {
try {
tff = TransformerFactory.newInstance();//獲得將DOM文檔轉化成XML文件的轉換器
tf = tff.newTransformer();
dom = new DOMSource(doc);//將DOM文檔轉化為DOMsourse對象,
sr = new StreamResult(new File("src/server.xml"));//獲得一個StreamResult類的對象,該對象是將XML文件轉換成其他對象的容器
tf.transform(dom, sr);//調用API,將DOM轉化成XML文件
} catch (Exception e) {
System.out.println("保存XML文件失敗");
}
}
/**
* 測試類
* @param a
*/
public static void main(String[] a) {
PraseXML.getInstancesPraseXML().getObjectInstances("Service");
}

}


/*

nodename 选取此节点的所有子节点
/ 从根节点选取
// 从匹配选择的当前节点选择文档中的节点,而不考虑它们的位置
. 选取当前节点
.. 选取当前节点的父节点
@
选取属性


如:

bookstore 选取 bookstore 元素的所有子节点
/bookstore
选取根元素 bookstore

注释:假如路径起始于正斜杠( / ),则此路径始终代表到某元素的绝对路径!
bookstore/book 选取所有属于 bookstore 的子元素的 book 元素。
//book 选取所有 book 子元素,而不管它们在文档中的位置。
bookstore//book 选择所有属于 bookstore 元素的后代的 book 元素,而不管它们位于 bookstore 之下的什么位置。
//@lang 选取所有名为 lang 的属性。


*/
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值