初始步骤如下:
1.创建解析工厂:
DocumentBuilderFactory
factory=DocumentBuilderFactory.newInstance();
2.指定DocumentBuilderDocumentBuilder db =
factory.newDocumentBuilder();
3.从文件构造一个Document,因为XML文件中已经指定了编码,所以这里不必了
Document xmlDoc = db.parse(new
File("book.xml"));
上面三步可以得到映射了指定的XML文件的Document,之后,通过这个Document可以来操作XML。
得到Document的根
Element root =
xmlDoc.getDocumentElement();
得到根后通过getTagName可以得到根节点名及其他一系列操作。
一.解析
获得XML某个元素的值:
NodeList list =
root.getElementsByTagName_r("page");
//NodeList对象存储的是指定元素的值的列表,
//我们可以通过遍历来得到指定元素的各个值:
for(int
i=0;i
Element element =
(Element)list.item(i); //得到"page"的第i+1组标签
String id =
element.getAttribute("id"); //获得ID属性
//
//得到标签title的列表
NodeList titleList =
element.getElementsByTagName_r("title");
//得到"title"的第1组标签,事实上也只有一组标签
Element titleElement =
(Element)titleList.item(0);
//获得title元素的第一个值
String title =
titleElement.getFirstChild().getNodeValue();
}
二.修改
Element
theBook=null, theElem=null;
// 创建指定类型的元素
theBook
= xmlDoc.createElement_x("book");
theElem =
xmlDoc.createElement_x("name");// 元素theElem设置数值,并作为theBook的子节点
theElem.setTextContent("新书");
theBook.a(theElem);
// 作为root的子节点
root.a(theBook);
三.输出
通过DOMSource和StreamResult完成
//首先创建转化工厂
TransformerFactory
transFactory=TransformerFactory.newInstance();
//创建Transformer,它能够将源树转换为结果树
Transformer transformer =
transFactory.newTransformer();
//接下来设置输出属性
transformer.setOutputProperty("indent", "yes");
DOMSource source =new
DOMSource();
source.setNode(xmlDoc);
StreamResult result = new StreamResult();
接下来有三种输出用途:
//1.将XML字符串输出到String字符串中
ByteArrayOutputStream baos = new
ByteArrayOutputStream();
result.setOutputStream(baos);
在执行完transformer.transform(source,
result)后,
加入String s =
baos.toString();
//2.直接输出到控制台上
result.setOutputStream(System.out);
//3.保存到指定的文件里面result.setOutputStream(new
FileOutputStream("book.xml"));
//开始执行将XML
Source转换为 Result
transformer.transform(source, result);