创建一个DocumentBuilderFactory对象。
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
利用DocumentBuilderFactory对象来创建一个DocumentBuilder对象。
DocumentBuilder db = dbf.newDocumentBuilder();
通过DocumentBuilder对象的parse()方法来加载XML文件返回一个Document对象。
Document document = db.parse("File.xml"); //File.xml为XML文件的路径
使用Document对象去操作XML文件。
使用getElementsByTagName()方法来获取节点集合,返回一个NodeList对象。
NodeList nodeList = document.getElementsByTagName("tagName"); //tagName为节点名称
遍历NodeList中每一个节点。
for(int i = 0; i < nodeList.getLength(); i++){
//使用NodeList中的item()方法获取一个节点,返回一个Node对象。
Node node = nodeList.item(i);
//遍历节点中所有的属性
//使用Node中的getAttributes()方法获取节点的所有属性的集合,返回一个NamedNodeMap对象。
/*
在知道属性名的情况下,也可以把nodeList.item(i)返回的Node对象强制转换为Element对象来获取相应的属性的值。
如获取属性id的值:
Element ele = (Element) nodeList.item(i);
String attrValue = ele.getAttribute("id");
*/
NamedNodeMap attrs = node.getAttributes();
for(int j = 0; j < attrs.getLength(); j++){
//也是使用item()方法,返回一个Node对象
Node attr = attrs.item(j);
//获取属性名
String attrName = attr.getNodeName();
//获取属性值
String attrValue = attr.getNodeValue();
}
//遍历节点中的子节点
//使用Node中的getChildNodes()方法获取节点的所有子节点,返回一个NodeList对象。
NodeList childNodes = node.getChildNodes();
//需要注意的是Java在解析XML文件的时候会把开始标签到结束标签之间的所有内容都看成是该标签的子节点,包括空格和换行。这一类没有用标签括起来的节点称为Text类型的节点,节点名叫#text。而有用标签括起来的节点叫Element类型的节点。
for(int k = 0; k < childNodes.getLength(); k++){
//因为上述的原因,我们需要区分出Text类型的节点和Element类型的节点。
if(childNodes.item(k).getNodeType() == Node.ELEMENT_NODE){ //判断子节点的类型是否为Element类型。
String childNodeName = childNodes.item(k).getNodeName(); //获取子节点的节点名。
//在获取子节点的节点值的时候不能单纯使用childNodes.item(k).getNodeValue()方法,因为子节点标签之间的内容被看作的是子节点的子节点。应该为:
String childNodeValue = childNodes.item(k).getTextContent();
// 或String childNodeValue = childNodes.item(k).getFirstChild().getNodeValue();
}
}
}
以上仅仅简单的获取了XML文件中的属性名、属性值、节点名和节点值。
Keep Going…