初始步骤如下:
1.创建解析工厂:
DocumentBuilderFactory factory=DocumentBuilderFactory.newInstance();
2.指定DocumentBuilder
DocumentBuilder 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
//NodeList对象存储的是指定元素的值的列表,
//我们可以通过遍历来得到指定元素的各个值:
for(int i=0;i<list.getLength();i++){
Element element = (Element)list.item(i); //得到"page"的第i+1组标签
String id = element.getAttribute("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;
//
//
//
三.输出
通过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);