DOM方式的XML文件读取和写入

首先构建通用方法getDocumentBuilder();

public DocumentBuilder getDocumentBuilder() {
        //创建DocumentBuilderFactory对象,由于工厂类对象不能通过构造函数创建,所以通过newInstance方法创建
        DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
        DocumentBuilder db = null;
        try {
            //创建DocumentBuilder对象,利用DocumentBuilderFactory的newDocumentBuilder方法创建
            db = dbf.newDocumentBuilder();
        } catch (ParserConfigurationException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        return db;
    }

然后构造ReadXML()方法

public void ReadXML() {

        // TODO Auto-generated method stub
        // 通过三个类建立Document对象将xml文件解析
        //利用Node对xml文件进行解析
        DocumentBuilder db = getDocumentBuilder();
        Document document = null;
        try {
            document = db.parse("books.xml");
        } catch (SAXException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        /**
         * 建立节点集合存储books.xml的节点,利用标签获得元素
         */
        NodeList bookList = document.getElementsByTagName("book");
        System.out.println("一共有" + bookList.getLength() + "本书");
        /**
         * 遍历每个book节点
         */
        for (int i = 0; i < bookList.getLength(); i++) {
            System.out.println("===================开始浏览第" + (i + 1)
                    + "本书的内容==========================");
            // 通过item()方法获取一个节点
            Node book = bookList.item(i);
            // 获取book节点的所有属性集合
            NamedNodeMap attrs = book.getAttributes();
            for (int j = 0; j < attrs.getLength(); j++) {
                // 在属性列表中提取属性利用item()方法
                Node attr = attrs.item(j);
                System.out.println("属性名" + attr.getNodeName());
                System.out.println("属性值" + attr.getNodeValue());
            }

            /**
             * 解析book节点的子节点
             */
            NodeList childNodes = book.getChildNodes();
            // 遍历childNodes获取每个节点的节点名和节点值
            for (int k = 0; k < childNodes.getLength(); k++) {

                Node child = childNodes.item(k);
                if (child.getNodeType() == Node.ELEMENT_NODE) {
                    System.out.println("第" + (k + 1) + "个节点");
                    System.out.println("---节点名是" + child.getNodeName());
                    //元素类型的节点的节点值均为null,在xml文件中的元素节点的内容是它的子节点,所以要提取节点中的内容需要用getFirstChild()方法
                    System.out.println("---节点值是"
                            + child.getFirstChild().getNodeValue());
                }

            }
        }

    }

最后是CreateXML()方法

public void createXML() {
        DocumentBuilder db = getDocumentBuilder();
        Document document = db.newDocument();
        document.setXmlStandalone(true);
        //创建bookstore元素节点、book元素节点和name元素节点
        Element bookstore = document.createElement("bookStore");
        Element book = document.createElement("book");
        Element name = document.createElement("name");
        name.setTextContent("大王子");//设置name节点的内容
        book.setAttribute("id", "1");//添加book节点的属性信息
        book.appendChild(name);//将book和name连接
        bookstore.appendChild(book);//将book和bookstore连接
        document.appendChild(bookstore);//将document和bookstore连接
        //建立TransformerFactory工厂类
        TransformerFactory tff = TransformerFactory.newInstance();
        //利用TransformerFactory工厂类建立Transformer
        Transformer tf=null;
        try {
            tf = tff.newTransformer();
            //使生成的XML文件自动换行
            tf.setOutputProperty(OutputKeys.INDENT, "yes");
            //开始转换XML文件,将文件保存到books1.xml中
            tf.transform(new DOMSource(document), new StreamResult(new File(
                    "books1.xml")));
        } catch (TransformerConfigurationException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (TransformerException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

    }

在ReadXML()中用到的类:
DocumentBuilderFactory DOM解析器的工厂类,用来建立DOM解析器
DocumentBuilder DOM解析器
Document 利用解析器解析XML文件后存储到此类型的对象中
Element 在Document的对象中提取元素节点
NodeList
Node
NamedNodeMap

在CreateXML()中用到的类:
DocumentBuilder
Document
Element
TransformerFactory
Transformer

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值