JAVA解析准备工作 创建DocumentBuilderFactory对象; 创建DocumentBuilder对象; 通过DocumentBuilder对象的parse方法加载解析解析 常用方法如下: getElementsByTagName(); ...
JAVA解析准备工作
创建DocumentBuilderFactory对象;
创建DocumentBuilder对象;
通过DocumentBuilder对象的parse方法加载
解析解析 常用方法如下:
getElementsByTagName();
getLength();
item();
getNodeName();
getNodeValue();
getNodeType();
*getAttributes(); node
*getAttribute("name"); element
getChildNodes();
getFirstChild();
常用的节点类型:
下面直接上代码
package pers.zww.import java.io.IOException;import javax.import javax.import javax.import org.w3c.dom.Document;import org.w3c.dom.NamedNodeMap;import org.w3c.dom.Node;import org.w3c.dom.NodeList;import org.public class Dom { public static void main(String[] args) { // 创建DocumentBuilderFactory对象 DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance(); // 创建DocumentBuilder对象 DocumentBuilder db; try { db = dbf.newDocumentBuilder(); // 通过DocumentBuilder对象的parse方法加载 Document document = db.parse("books.); // 获取book节点集合 NodeList bookList = document.getElementsByTagName("book"); // 通过noodlist的getLength()方法,获取长度 System.out.println(bookList.getLength()); // 遍历book节点 for (int i = 0; i < bookList.getLength(); i++) { System.out.println("======================="); // item(i)方法获取节点 Node book = (Node) bookList.item(i); // 获取book节点的所有属性集合 NamedNodeMap attrs = book.getAttributes(); // 遍历book的属性 System.out.println("第" + (i + 1) + "本书共有" + attrs.getLength() + "个属性"); for (int j = 0; j < attrs.getLength(); j++) { /* * 节点类型 TYPE * element 1 * attr 2 * text 3 */ /* * 若只有一个属性则 * 将book节点node强制类型转换 * 用element的getAttribute("id")方法 */ // item(i)方法获取属性 Node attr = attrs.item(j); // 获取属性名 System.out.print("属性名:" + attr.getNodeName()); // 获取属性值 System.out.println(" && 属性值:" + attr.getNodeValue()); //解析book的子节点 NodeList childNodes=book.getChildNodes(); //获取每个节点的节点名/值 System.out.println("共有"+childNodes.getLength()+"个子节点"); for (int k = 0; k < childNodes.getLength(); k++) { //区分text类型的node以及element类型的node if (childNodes.item(k).getNodeType()==Node.ELEMENT_NODE) { //获取element类型节点的节点名 System.out.print("节点名 "+childNodes.item(k).getNodeName()); //获取element类型节点的节点值 //法一: System.out.println(" && 节点值 "+childNodes.item(k).getFirstChild().getNodeValue()); //法二: //子节点的所有值 //System.out.println(" && 节点值 "+childNodes.item(k).getTextContent()); /* * 不同点: * 若在name节点下再添加一个节点例如<h>xiumu</h>时,法一的值为null, * 而法二的值为xiumuJAVA编程思想 */ } } } } } catch (ParserConfigurationException | SAXException | IOException e) { e.printStackTrace(); } }}
海外公司注册、海外银行开户、跨境平台代入驻、VAT、EPR等知识和在线办理:https://www.xlkjsw.com
原标题:JAVA解析XML之DOM方式
关键词:JAVA
*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们:
admin#shaoqun.com
(#换成@)。