// 1.生成DOM解析器工厂对象 DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance(); // 2.从解析器工厂得到一个解析器对象 DocumentBuilder db = dbf.newDocumentBuilder(); // 3.加载要解析的xml文档 Document doc = db.parse("student.xml"); // 4.读取根节点 Element ele = doc.getDocumentElement(); System.out.println("根节点的名字是:" + ele.getNodeName()); // 获取根节点底下所有子节点是个集合 NodeList list = ele.getChildNodes(); for (int i = 0; i < list.getLength(); i++) { // 判断节点是否为空 if (list.item(i).getNodeType() == Node.ELEMENT_NODE) { Node node = list.item(i); System.out.println("节点名:" + node.getNodeName() + ",节点类型:" + node.getNodeType()); NodeList sons = node.getChildNodes(); System.out.println("每个student节点下有:" + sons.getLength() + "个子节点"); for (int j = 0; j < sons.getLength(); j++) { //判断节点是否为空! if (sons.item(j).getNodeType() == Node.ELEMENT_NODE) { Node son = sons.item(j); System.out.println("son的节点名称:" + son.getNodeName() + ",类型:" + son.getNodeType() + ",值:" + son.getFirstChild().getNodeValue()); } } }
// 使用for循环一次查出所有节点内容 for (Node first = ele.getLastChild(); first != null; first = first .getPreviousSibling()) { if (first.getNodeType() == Node.ELEMENT_NODE) { System.out.println("节点名:" + first.getNodeName() + ",节点类型:" + first.getNodeType()); for (Node son = first.getLastChild(); son != null; son = son .getPreviousSibling()) { if (son.getNodeType() == Node.ELEMENT_NODE) { System.out.println("节点名:" + son.getNodeName() + ",节点值:" + son.getFirstChild().getNodeValue()); } } } }