DocumentBuilderFactory解析XML

(1) javax.xml.parsers 包中的DocumentBuilderFactory用于创建DOM模式的解析器对象 , DocumentBuilderFactory是一个抽象工厂类,它不能直接实例化,但该类提供了一个newInstance方法 ,这个方法会根据本地平台默认安装的解析器,自动创建一个工厂的对象并返回。

(2) 调用 DocumentBuilderFactory.newInstance() 方法得到创建 DOM 解析器的工厂。

DocumentBuilderFactory doc=DocumentBuilderFactory.newInstance();
1
(3) 调用工厂对象的 newDocumentBuilder方法得到 DOM 解析器对象。

DocumentBuilder db=doc.newDocumentBuilder();
1
(4) 把要解析的 XML 文档转化为输入流,以便 DOM 解析器解析它

InputStream is= new  FileInputStream("test.xml");    
1
(5) 调用 DOM 解析器对象的 parse() 方法解析 XML 文档,得到代表整个文档的 Document 对象,进行可以利用DOM特性对整个XML文档进行操作了。

 Document doc=dombuilder.parse(is);
1
(6) 得到 XML 文档的根节点

Element root=doc.getDocumentElement();
1
(7) 得到节点的子节点

  NodeList users=root.getChildNodes();
1
相关java案例:

package cn.com.snxun.test;

import java.io.File;
import java.io.FileInputStream;
import java.io.InputStream;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;

import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;

public class XmlReader {
    public XmlReader() {
        DocumentBuilderFactory domfac = DocumentBuilderFactory.newInstance();
        try {
            DocumentBuilder domBuilder = domfac.newDocumentBuilder();
            InputStream is = new FileInputStream(new File(
                    "C:/Users/sony/Desktop/test.xml"));
            Document doc = domBuilder.parse(is);
            Element root = doc.getDocumentElement();
            NodeList users = root.getChildNodes();
            if (users != null) {
                for (int i = 0; i < users.getLength(); i++) {
                    Node user = users.item(i);
                    // TEXT_NODE 说明该节点是文本节点
                    // ELEMENT_NODE 说明该节点是个元素节点
                    if (user.getNodeType() == Node.ELEMENT_NODE) {
                        // (7)取得节点的属性值
                        // String email = user.getAttributes()
                        // .getNamedItem("email").getNodeValue();
                        // System.out.println(email);
                        // 注意,节点的属性也是它的子节点。它的节点类型也是Node.ELEMENT_NODE
                        // (8)轮循子节点
                        for (Node node = user.getFirstChild(); node != null; node = node
                                .getNextSibling()) {
                            if (node.getNodeType() == Node.ELEMENT_NODE) {
                                if (node.getNodeName().equals("name")) {
                                    String name = node.getNodeValue();
                                    String name1 = node.getFirstChild()
                                            .getNodeValue();
                                    System.out.println("name==" + name);
                                    System.out.println("name1==" + name1);
                                }
                                if (node.getNodeName().equals("price")) {
                                    String price = node.getFirstChild()
                                            .getNodeValue();
                                    System.out.println(price);
                                }
                            }
                        }
                    }
                }
            }
            NodeList node = root.getElementsByTagName("string");
            if (node != null) {
                for (int i = 0; i < node.getLength(); i++) {
                    Node str = node.item(i);
                    String s = str.getFirstChild().getNodeValue();
                    System.out.println(s);
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
        }

    }

    public static void main(String[] args) {
        XmlReader xmlReader = new XmlReader();

    }
}

xml文件:

<?xml version="1.0" encoding="GB2312" standalone="no"?>  
<users>
    <user email="www.baidu.com">
        <name>张三</name>
        <age>18</age>
        <sex>男</sex>    
    </user>
    <user>
        <name>李四</name>
        <age>16</age>
        <sex>女</sex>    
    </user>
    <user>
        <name>王五</name>
        <age>25</age>
        <sex>不明</sex>   
    </user>

</users>

上面的是我入门的笔记,以备不时之需。


--------------------- 
作者:懒惰的小肥肥 
来源:CSDN 
原文:https://blog.csdn.net/hua1017177499/article/details/78985166 
版权声明:本文为博主原创文章,转载请附上博文链接!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.IOException; import java.io.InputStream; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.parsers.ParserConfigurationException; import org.w3c.dom.Document; import org.w3c.dom.Element; import org.w3c.dom.Node; import org.w3c.dom.NodeList; import org.xml.sax.SAXException; public class ReadXML { public static void main(String[] args) { try { // 得到DOM解析器的工厂实例 DocumentBuilderFactory domfac = DocumentBuilderFactory.newInstance(); // 从DOM工厂获得DOM解析DocumentBuilder dombuilder = domfac.newDocumentBuilder(); // 把要解析XML文档转化为输入流,以便DOM解析解析它 InputStream is = new FileInputStream("test.xml"); // 解析XML文档的输入流,得到一个Document Document doc = dombuilder.parse(is); // 得到XML文档的根节点 Element root = doc.getDocumentElement(); // 得到节点的子节点 NodeList books = root.getChildNodes(); if (books != null) { // 轮循子节点 for (int i = 0; i < books.getLength(); i++) { // 获取book节点 Node book = books.item(i); if (book.getNodeType() == Node.ELEMENT_NODE) { // 取得节点的属性值 String email = book.getAttributes().getNamedItem( "email").getNodeValue(); System.out.println(email); // 轮循子节点 for (Node node = book.getFirstChild(); node != null; node = node.getNextSibling()) { if (node.getNodeType() == Node.ELEMENT_NODE) { if (node.getNodeName().equals("name")) { // 获得节点的文本值 String name = node.getFirstChild() .getNodeValue(); System.out.println(name); } if (node.getNodeName().equals("price")) { // 获得节点的文本值 String price = node.getFirstChild() .getNodeValue(); System.out.println(price); } } } } } } } // 异常处理 catch (ParserConfigurationException e) { e.printStackTrace(); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (SAXException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值