国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

JAVA操作XML實例分析

2019-11-26 15:15:59
字體:
供稿:網(wǎng)友

本文實例講述了JAVA操作XML的方法。分享給大家供大家參考。具體如下:

java代碼如下:

復制代碼 代碼如下:
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import org.w3c.dom.*;
import org.xml.sax.SAXException;
import javax.xml.parsers.*;
import javax.xml.transform.*;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.*;
import javax.xml.xpath.*;
public class Test {
    public static void main(String[] args) {
        DocumentBuilderFactory factory=DocumentBuilderFactory.newInstance();
        Element theBook=null, theElem=null, root=null;
        try {
            factory.setIgnoringElementContentWhitespace(true);
            DocumentBuilder db=factory.newDocumentBuilder();
            Document xmldoc=db.parse(new File("Test1.xml"));
            root=xmldoc.getDocumentElement();
            theBook=(Element) selectSingleNode("/books/book[name='哈里波特']", root);
            System.out.println("--- 查詢找《哈里波特》 ----");
            Element nameNode=(Element)theBook.getElementsByTagName("price").item(0);
            String name=nameNode.getFirstChild().getNodeValue();
            System.out.println(name);
            output(theBook);
            System.out.println("=============selectSingleNode(books/book[name='哈里波特'], root)==================");
            //--- 新建一本書開始 ----
            theBook=xmldoc.createElement("book");
            theElem=xmldoc.createElement("name");
            theElem.setTextContent("新書");
            theBook.appendChild(theElem);
            theElem=xmldoc.createElement("price");
            theElem.setTextContent("20");
            theBook.appendChild(theElem);
            theElem=xmldoc.createElement("memo");
            theElem.setTextContent("新書的更好看。");
            theBook.appendChild(theElem);
            root.appendChild(theBook);
            System.out.println("--- 新建一本書開始 ----");
            output(xmldoc);
            System.out.println("==============================");
            //--- 新建一本書完成 ----
            //--- 下面對《哈里波特》做一些修改。 ----
            //--- 查詢找《哈里波特》----
            //--- 此時修改這本書的價格 -----
            theBook.getElementsByTagName("price").item(0).setTextContent("15");//getElementsByTagName返回的是NodeList,所以要跟上item(0)。另外,getElementsByTagName("price")相當于xpath的".//price"。
            System.out.println("--- 此時修改這本書的價格 ----");
            output(theBook);
            //--- 另外還想加一個屬性id,值為B01 ----
            theBook.setAttribute("id", "B01");
            System.out.println("--- 另外還想加一個屬性id,值為B01 ----");
            output(theBook);
            //--- 對《哈里波特》修改完成。 ----
            //--- 要用id屬性刪除《三國演義》這本書 ----
            theBook=(Element) selectSingleNode("/books/book[@id='B02']", root);
            System.out.println("--- 要用id屬性刪除《三國演義》這本書 ----");
            output(theBook);
            theBook.getParentNode().removeChild(theBook);
            System.out.println("--- 刪除后的XML ----");
            output(xmldoc);
            //--- 再將所有價格低于10的書刪除 ----
            NodeList someBooks=selectNodes("/books/book[price<10]", root);
            System.out.println("--- 再將所有價格低于10的書刪除 ---");
            System.out.println("--- 符合條件的書有 "+someBooks.getLength()+"本。 ---");
            for(int i=0;i<someBooks.getLength();i++) {
                someBooks.item(i).getParentNode().removeChild(someBooks.item(i));
            }
            output(xmldoc);
            saveXml("Test1_Edited.xml", xmldoc);
        } catch (ParserConfigurationException e) {
            e.printStackTrace();
        } catch (SAXException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
    public static void output(Node node) {//將node的XML字符串輸出到控制臺
        TransformerFactory transFactory=TransformerFactory.newInstance();
        try {
            Transformer transformer = transFactory.newTransformer();
            transformer.setOutputProperty("encoding", "gb2312");
            transformer.setOutputProperty("indent", "yes");
            DOMSource source=new DOMSource();
            source.setNode(node);
            StreamResult result=new StreamResult();
            result.setOutputStream(System.out);
            transformer.transform(source, result);
        } catch (TransformerConfigurationException e) {
            e.printStackTrace();
        } catch (TransformerException e) {
            e.printStackTrace();
        }  
    }
    public static Node selectSingleNode(String express, Object source) {//查找節(jié)點,并返回第一個符合條件節(jié)點
        Node result=null;
        XPathFactory xpathFactory=XPathFactory.newInstance();
        XPath xpath=xpathFactory.newXPath();
        try {
            result=(Node) xpath.evaluate(express, source, XPathConstants.NODE);
        } catch (XPathExpressionException e) {
            e.printStackTrace();
        }
        return result;
    }
    public static NodeList selectNodes(String express, Object source) {//查找節(jié)點,返回符合條件的節(jié)點集。
        NodeList result=null;
        XPathFactory xpathFactory=XPathFactory.newInstance();
        XPath xpath=xpathFactory.newXPath();
        try {
            result=(NodeList) xpath.evaluate(express, source, XPathConstants.NODESET);
        } catch (XPathExpressionException e) {
            e.printStackTrace();
        }
        return result;
    }
    public static void saveXml(String fileName, Document doc) {//將Document輸出到文件
        TransformerFactory transFactory=TransformerFactory.newInstance();
        try {
            Transformer transformer = transFactory.newTransformer();
            transformer.setOutputProperty("indent", "yes");
            DOMSource source=new DOMSource();
            source.setNode(doc);
            StreamResult result=new StreamResult();
            result.setOutputStream(new FileOutputStream(fileName));
            transformer.transform(source, result);
        } catch (TransformerConfigurationException e) {
            e.printStackTrace();
        } catch (TransformerException e) {
            e.printStackTrace();
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        }  
    }
}

 
XML文件如下:
復制代碼 代碼如下:
<?xml version="1.0" encoding="GBK"?>
<books>
<book>
<name>哈里波特</name>
<price>10</price>
<memo>這是一本很好看的書。</memo>
</book>
<book id="B02">
<name>三國演義</name>
<price>10</price>
<memo>四大名著之一。</memo>
</book>
<book id="B03">
<name>水滸</name>
<price>6</price>
<memo>四大名著之一。</memo>
</book>
<book id="B04">
<name>紅樓</name>
<price>5</price>
<memo>四大名著之一。</memo>
</book>
</books>

希望本文所述對大家的java程序設計有所幫助。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 法库县| 上思县| 皋兰县| 松江区| 准格尔旗| 瓮安县| 观塘区| 广丰县| 清涧县| 丰镇市| 衡水市| 天门市| 岳普湖县| 大姚县| 仙桃市| 平武县| 建始县| 聊城市| 上蔡县| 榆树市| 成都市| 巴林左旗| 石林| 镶黄旗| 封开县| 商南县| 木兰县| 白河县| 正蓝旗| 观塘区| 灵台县| 余庆县| 沅江市| 扬中市| 江源县| 三穗县| 泰州市| 大新县| 辽宁省| 扬州市| 定安县|