zoukankan      html  css  js  c++  java
  • JAVA解析XML之DOM方式

    JAVA解析XML之DOM方式

    准备工作

      创建DocumentBuilderFactory对象;

        创建DocumentBuilder对象;

      通过DocumentBuilder对象的parse方法加载xml

    解析XML文件的属性名和属性值

    解析XML文件的节点名和节点值

      常用方法如下:

        getElementsByTagName();

        getLength();

        item();

        getNodeName();

        getNodeValue();

        getNodeType();

        *getAttributes();  node

        *getAttribute("name");  element

        getChildNodes();

        getFirstChild();

      常用的节点类型:

        

     下面直接上代码

    package pers.zww.xml;
    
    import java.io.IOException;
    
    import javax.xml.parsers.DocumentBuilder;
    import javax.xml.parsers.DocumentBuilderFactory;
    import javax.xml.parsers.ParserConfigurationException;
    
    import org.w3c.dom.Document;
    import org.w3c.dom.NamedNodeMap;
    import org.w3c.dom.Node;
    import org.w3c.dom.NodeList;
    import org.xml.sax.SAXException;
    
    public class Dom {
        public static void main(String[] args) {
            // 创建DocumentBuilderFactory对象
            DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
            // 创建DocumentBuilder对象
            DocumentBuilder db;
            try {
                db = dbf.newDocumentBuilder();
                // 通过DocumentBuilder对象的parse方法加载xml
                Document document = db.parse("books.xml");
                // 获取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 <?xml version="1.0" encoding="UTF-8"?>
     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

    要点

      当已确定节点的属性只有一个时,可将节点强制转换为element,并调用其getAttribute("name")方法;

      getLength()方法子节点的个数时,将空白和换行也算了进去;

    参考资料

      慕课网JessicaJiang老师视频教程 点击链接

  • 相关阅读:
    SVN cleanup操作反复失败解决办法
    mysql常用命令之-用户密码修改
    properties 配置文件中值换行的问题
    在每一行行尾添加内容
    Java 毫秒转换为日期类型、日期转换为毫秒
    SimpleDateFormat 12小时制以及24小时制的写法
    java校验时间格式 HH:MM
    ClassLoader 详解及用途(写的不错)
    ObjectInputStream类和ObjectInputStream类的使用
    logback 详解
  • 原文地址:https://www.cnblogs.com/zhaoww/p/4713882.html
Copyright © 2011-2022 走看看