你的位置:首页 > Java教程

[Java教程]JAVA解析XML之DOM方式


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();    }  }}

View Code

 

 1 <??> 2 <bookstore> 3   <book id="1"> 4     <name><h>xiumu</h>JAVA编程思想</name> 5     <anthor>****</anthor> 6     <year>2000</year> 7   </book> 8   <book id="2"> 9     <name>疯狂JAVA系列</name>10     <anthor>李刚</anthor>11     <price>89</price>12   </book>13 </bookstore>

View Code

 参考资料

  慕课网JessicaJiang老师视频教程