JAVA中使用DOM解析XML文件

JAVA中使用DOM解析XML文件:

创建DocumentBuilderFactory的对象 DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
创建DocumentBuilder对象
通过documentBuilder对象的parser方法加载xml文件到当前项目下
获取所有XML文件内节点的集合 getElementsByTagName()方法
遍历每一个节点
通过item(i)方法获取节点
获取节点的所有属性集合 getAttributes()方法
遍历节点的属性 getNodeValue()
通过item()方法获取节点的属性
通过getNodeName()和getNodeValue()获取属性名和属性值
通过getChildNodes()获取子节点的集合
遍 历子节点,获取子节点属性名和属性值(注意:区分text 类型的node,使用判断 if(chilNod.item(k).getNodeType() == Node.ELEMENT_NODE))

以获取book.xml文件为例

<?xml version="1.0" encoding="UTF-8"?>
<books>
    <book id="001">
        <title>Harry Potter</title>
        <author>J K. Rowling</author>
    </book>
    <book id="002">
        <title>Learning XML</title>
        <author>Erik T. Ray</author>
    </book>
</books>

解析代码如下:

public class testXML {
    public static void main(String[] args) {
        // 创建DocumentBuilderFactory的对象
        DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
        try {
            //创建DocumentBuilder对象
            DocumentBuilder db = dbf.newDocumentBuilder();
            //通过documentBuilder对象 的parser方法加载books。xml文件到当前项目下
            Document document = db.parse("books.xml");
            //获取所有book节点的集合
            NodeList booklist = document.getElementsByTagName("book");
            System.out.println("一共有" + booklist.getLength() + "本书");
            //遍历每一个book节点
            for (int i = 0; i <= booklist.getLength(); i++) {
                //通过item(i)方法获取book节点
                Node book = booklist.item(i);
                //获取book节点的所有属性集合
                NamedNodeMap attrs = book.getAttributes();
                System.out.println("第" + (i + 1) + "本书共有" + attrs.getLength() + "个属性");
                //遍历book的属性
                for (int j = 0; j < attrs.getLength(); j++) {
                    //通过item方法获取book节点的属性
                    Node attr = attrs.item(j);
                    //获取属性名
                    System.out.print("属性名:" + attr.getNodeName());
                    //获取属性值
                    System.out.println("--属性值" + attr.getNodeValue());
                    NodeList chilNod = book.getChildNodes();
                    System.out.println("第" + (i + 1) + "本书共有" + chilNod.getLength() + "个子节点");
                    for (int k = 0; k < chilNod.getLength(); k++) {
                        Node chil = chilNod.item(k);
                        //区分text 类型node
                        if (chilNod.item(k).getNodeType() == Node.ELEMENT_NODE) {
                            System.out.print("子节点名:" + chil.getNodeName() + ":");
                            System.out.println("    子节点值:" + chilNod.item(k).getFirstChild().getNodeValue());
                            //System.out.println("子节点值:"+chilNod.item(k).getTextContent());
                        }
                    }
                }
            }
        } catch (ParserConfigurationException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (SAXException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }
}
原文地址:https://www.cnblogs.com/grasp/p/10114982.html