首先构建通用方法getDocumentBuilder();
public DocumentBuilder getDocumentBuilder() {
//创建DocumentBuilderFactory对象,由于工厂类对象不能通过构造函数创建,所以通过newInstance方法创建
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
DocumentBuilder db = null;
try {
//创建DocumentBuilder对象,利用DocumentBuilderFactory的newDocumentBuilder方法创建
db = dbf.newDocumentBuilder();
} catch (ParserConfigurationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return db;
}
然后构造ReadXML()方法
public void ReadXML() {
// TODO Auto-generated method stub
// 通过三个类建立Document对象将xml文件解析
//利用Node对xml文件进行解析
DocumentBuilder db = getDocumentBuilder();
Document document = null;
try {
document = db.parse("books.xml");
} catch (SAXException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
/**
* 建立节点集合存储books.xml的节点,利用标签获得元素
*/
NodeList bookList = document.getElementsByTagName("book");
System.out.println("一共有" + bookList.getLength() + "本书");
/**
* 遍历每个book节点
*/
for (int i = 0; i < bookList.getLength(); i++) {
System.out.println("===================开始浏览第" + (i + 1)
+ "本书的内容==========================");
// 通过item()方法获取一个节点
Node book = bookList.item(i);
// 获取book节点的所有属性集合
NamedNodeMap attrs = book.getAttributes();
for (int j = 0; j < attrs.getLength(); j++) {
// 在属性列表中提取属性利用item()方法
Node attr = attrs.item(j);
System.out.println("属性名" + attr.getNodeName());
System.out.println("属性值" + attr.getNodeValue());
}
/**
* 解析book节点的子节点
*/
NodeList childNodes = book.getChildNodes();
// 遍历childNodes获取每个节点的节点名和节点值
for (int k = 0; k < childNodes.getLength(); k++) {
Node child = childNodes.item(k);
if (child.getNodeType() == Node.ELEMENT_NODE) {
System.out.println("第" + (k + 1) + "个节点");
System.out.println("---节点名是" + child.getNodeName());
//元素类型的节点的节点值均为null,在xml文件中的元素节点的内容是它的子节点,所以要提取节点中的内容需要用getFirstChild()方法
System.out.println("---节点值是"
+ child.getFirstChild().getNodeValue());
}
}
}
}
最后是CreateXML()方法
public void createXML() {
DocumentBuilder db = getDocumentBuilder();
Document document = db.newDocument();
document.setXmlStandalone(true);
//创建bookstore元素节点、book元素节点和name元素节点
Element bookstore = document.createElement("bookStore");
Element book = document.createElement("book");
Element name = document.createElement("name");
name.setTextContent("大王子");//设置name节点的内容
book.setAttribute("id", "1");//添加book节点的属性信息
book.appendChild(name);//将book和name连接
bookstore.appendChild(book);//将book和bookstore连接
document.appendChild(bookstore);//将document和bookstore连接
//建立TransformerFactory工厂类
TransformerFactory tff = TransformerFactory.newInstance();
//利用TransformerFactory工厂类建立Transformer
Transformer tf=null;
try {
tf = tff.newTransformer();
//使生成的XML文件自动换行
tf.setOutputProperty(OutputKeys.INDENT, "yes");
//开始转换XML文件,将文件保存到books1.xml中
tf.transform(new DOMSource(document), new StreamResult(new File(
"books1.xml")));
} catch (TransformerConfigurationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (TransformerException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
在ReadXML()中用到的类:
DocumentBuilderFactory DOM解析器的工厂类,用来建立DOM解析器
DocumentBuilder DOM解析器
Document 利用解析器解析XML文件后存储到此类型的对象中
Element 在Document的对象中提取元素节点
NodeList
Node
NamedNodeMap
在CreateXML()中用到的类:
DocumentBuilder
Document
Element
TransformerFactory
Transformer