创建文档时,首先要用DocumentBuilderFactory创建一个DocumentBuilder
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
然后使用Documentbuilder创建一个Document
Document doc=builder.newDocument();
创建一个节点元素
Element el = doc.createElement(elementName);
添加到父节点上
parentElement.appendChild(el);
为元素添加属性和值
element.setAttribute(propetyName, propertyValue);
最后保存Document
TransformerFactory tf = TransformerFactory.newInstance();
Transformer transformer = tf.newTransformer();
DOMSource source = new DOMSource(doc);
transformer.setOutputProperty(OutputKeys.ENCODING, "UTF-8");
transformer.setOutputProperty(OutputKeys.INDENT, "yes");
ByteArrayOutputStream buf = new ByteArrayOutputStream();
StreamResult result = new StreamResult(buf);
transformer.transform(source, result);
FileOutputStream file = new FileOutputStream(filePath);
file.write(buf.toByteArray());
在读取XML的时候,同样先创建Document,然后读取文件到Document
DocumentBuilderFactory dbf=DocumentBuilderFactory.newInstance();
DocumentBuilder db=dbf.newDocumentBuilder();
Document doc=db.parse(file);
找到根节点
Element root=doc.getDocumentElement();
然后遍历该节点的所有子节点(注意:i的值每次循环是+2)
NodeList list=root.getChildNodes();
for(int i=1;i<list.getLength();i+=2){
Node n=list.item(i);
}
想要得到节点的某属性的值
String word=n.getAttributes().getNamedItem("attr").getNodeValue();
得到某节点文本处的值
String word=n.getTextContent();
其他的一些方法也类似,参考JDK API文档吧