91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java中org.w3c.dom.Document類方法引用報錯怎么辦

發布時間:2021-08-07 10:29:07 來源:億速云 閱讀:256 作者:小新 欄目:開發技術

這篇文章主要介紹了Java中org.w3c.dom.Document類方法引用報錯怎么辦,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

org.w3c.dom.Document 類方法引用報錯

The method setXmlVersion(String) is undefined for the type Document

開發時我們可能會碰到這樣的問題,它產生的原因是我們實際需要調用的是 JDK 環境 rt.jar 下的 org.w3c.dom.org.w3c.dom.Document ,但事實上 Eclipse 等 IDE 工具此時自動為我們調用的是 J2EE 中的 xerces\xmlParserAPIs\2.6.2\xmlParserAPIs-2.6.2.jar ,這一點通過 Ctrl 左鍵點擊 Document 類可以發現。

發現問題出在哪里就好解決了

我們需要做的是調整 Eclipse 的調用順序

項目右鍵 > Properties > Java Build Path > 右邊 Order and Export

把 JRE System Library 通過點擊 Up 按鈕放到 J2EE(Maven Dependencies) 的上面即可。

org.w3c.dom(java dom)解析XML文檔

位于org.w3c.dom操作XML會比較簡單,就是將XML看做是一顆樹,DOM就是對這顆樹的一個數據結構的描述,但對大型XML文件效果可能會不理想

首先來了解點Java DOM 的 API:

1.解析器工廠類:DocumentBuilderFactory

創建的方法:

DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();

2.解析器:DocumentBuilder

創建方法:通過解析器工廠類來獲得

DocumentBuilder db = dbf.newDocumentBuilder();

3.文檔樹模型Document

創建方法:a.通過xml文檔 Document doc = db.parse("bean.xml"); b.將需要解析的xml文檔轉化為輸入流 InputStream is = new FileInputStream("bean.xml");

Document doc = db.parse(is);

Document對象代表了一個XML文檔的模型樹,所有的其他Node都以一定的順序包含在Document對象之內,排列成一個樹狀結構,以后對XML文檔的所有操作都與解析器無關,

直接在這個Document對象上進行操作即可;

包含的方法:

Java中org.w3c.dom.Document類方法引用報錯怎么辦

Java中org.w3c.dom.Document類方法引用報錯怎么辦

4.節點列表類NodeList

NodeList代表了一個包含一個或者多個Node的列表,根據操作可以將其簡化的看做為數組

Java中org.w3c.dom.Document類方法引用報錯怎么辦

5.節點類Node

Node對象是DOM中最基本的對象,代表了文檔樹中的抽象節點。但在實際使用中很少會直接使用Node對象,而是使用Node對象的子對象Element,Attr,Text等

6.元素類Element

是Node類最主要的子對象,在元素中可以包含屬性,因而Element中有存取其屬性的方法

Java中org.w3c.dom.Document類方法引用報錯怎么辦

7.屬性類Attr

代表某個元素的屬性,雖然Attr繼承自Node接口,但因為Attr是包含在Element中的,但并不能將其看做是Element的子對象,因為Attr并不是DOM樹的一部分

基本的知識就到此結束,更加具體的大家可以參閱JDK API文檔

實戰:

1.使用DOM來遍歷XML文檔中的全部內容并且插入元素:

school.xml文檔:

<?xml version = "1.0" encoding = "utf-8"?>
<School>
    <Student>
        <Name>沈浪</Name>
        <Num>1006010022</Num>
        <Classes>信管2</Classes>
        <Address>浙江杭州3</Address>
        <Tel>123456</Tel>
    </Student>
    <Student>
        <Name>沈1</Name>
        <Num>1006010033</Num>
        <Classes>信管1</Classes>
        <Address>浙江杭州4</Address>
        <Tel>234567</Tel>
    </Student>
    <Student>
        <Name>沈2</Name>
        <Num>1006010044</Num>
        <Classes>生工2</Classes>
        <Address>浙江杭州1</Address>
        <Tel>345678</Tel>
    </Student>
    <Student>
        <Name>沈3</Name>
        <Num>1006010055</Num>
        <Classes>電子2</Classes>
        <Address>浙江杭州2</Address>
        <Tel>456789</Tel>
    </Student>
</School>

DomDemo.java

package xidian.sl.dom;
import java.io.FileOutputStream;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.apache.crimson.tree.XmlDocument;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NodeList;
public class DomDemo {
    /**
     * 遍歷xml文檔
     * */
    public static void queryXml(){
        try{
            //得到DOM解析器的工廠實例
            DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
            //從DOM工廠中獲得DOM解析器
            DocumentBuilder dbBuilder = dbFactory.newDocumentBuilder();
            //把要解析的xml文檔讀入DOM解析器
            Document doc = dbBuilder.parse("src/xidian/sl/dom/school.xml");
            System.out.println("處理該文檔的DomImplementation對象  = "+ doc.getImplementation());
            //得到文檔名稱為Student的元素的節點列表
            NodeList nList = doc.getElementsByTagName("Student");
            //遍歷該集合,顯示結合中的元素及其子元素的名字
            for(int i = 0; i< nList.getLength() ; i ++){
                Element node = (Element)nList.item(i);
                System.out.println("Name: "+ node.getElementsByTagName("Name").item(0).getFirstChild().getNodeValue());
                System.out.println("Num: "+ node.getElementsByTagName("Num").item(0).getFirstChild().getNodeValue());
                System.out.println("Classes: "+ node.getElementsByTagName("Classes").item(0).getFirstChild().getNodeValue());
                System.out.println("Address: "+ node.getElementsByTagName("Address").item(0).getFirstChild().getNodeValue());
                System.out.println("Tel: "+ node.getElementsByTagName("Tel").item(0).getFirstChild().getNodeValue());
            }
            
        }catch (Exception e) {
            // TODO: handle exception
            e.printStackTrace();
        }
    }
    /**
     * 向已存在的xml文件中插入元素
     * */
    public static void insertXml(){
        Element school = null;
        Element student = null;
        Element name = null;
        Element num = null;
        Element classes = null;
        Element address = null;
        Element tel = null;
        try{
            //得到DOM解析器的工廠實例
            DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
            //從DOM工廠中獲得DOM解析器
            DocumentBuilder dbBuilder = dbFactory.newDocumentBuilder();
            //把要解析的xml文檔讀入DOM解析器
            Document doc = dbBuilder.parse("src/xidian/sl/dom/school.xml");
            //得到文檔名稱為Student的元素的節點列表
            NodeList nList = doc.getElementsByTagName("School");
            school = (Element)nList.item(0);
            //創建名稱為Student的元素
            student = doc.createElement("Student");
            //設置元素Student的屬性值為231
            student.setAttribute("examId", "23");
            //創建名稱為Name的元素
            name = doc.createElement("Name");
            //創建名稱為 香香 的文本節點并作為子節點添加到name元素中
            name.appendChild(doc.createTextNode("香香"));
            //將name子元素添加到student中
            student.appendChild(name);
            /**
             * 下面的元素依次加入即可
             * */
            num = doc.createElement("Num");
            num.appendChild(doc.createTextNode("1006010066"));
            student.appendChild(num);
            
            classes = doc.createElement("Classes");
            classes.appendChild(doc.createTextNode("眼視光5"));
            student.appendChild(classes);
            
            address = doc.createElement("Address");
            address.appendChild(doc.createTextNode("浙江溫州"));
            student.appendChild(address);
            
            tel = doc.createElement("Tel");
            tel.appendChild(doc.createTextNode("123890"));
            student.appendChild(tel);
            
            //將student作為子元素添加到樹的根節點school
            school.appendChild(student);
            //將內存中的文檔通過文件流生成insertSchool.xml,XmlDocument位于crison.jar下
            ((XmlDocument)doc).write(new FileOutputStream("src/xidian/sl/dom/insertSchool.xml"));
            System.out.println("成功");
        }catch (Exception e) {
            // TODO: handle exception
            e.printStackTrace();
        }    
    }
    public static void main(String[] args){
        //讀取
        DomDemo.queryXml();
        //插入
        DomDemo.insertXml();
    }
}

運行后結果:

Java中org.w3c.dom.Document類方法引用報錯怎么辦

然后到目錄下查看生成的xml文件:

Java中org.w3c.dom.Document類方法引用報錯怎么辦

打開查看內容:

Java中org.w3c.dom.Document類方法引用報錯怎么辦

上面添加元素后輸出的文件與之前的文件不是同一個文件,如果需要輸出到原文件中,那么只要將路徑改為原文間路徑即可:src/xidian/sl/dom/school.xml

2.創建XML過程與插入過程相似,就是Document需要創建

package xidian.sl.dom;
import java.io.FileOutputStream;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.apache.crimson.tree.XmlDocument;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
public class CreateNewDom {
    /**
     * 創建xml文檔
     * */
    public static void createDom(){
        Document doc;
        Element school,student;
        Element name = null;
        Element num = null;
        Element classes = null;
        Element address = null;
        Element tel = null;
        try{
            //得到DOM解析器的工廠實例
            DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
            //從DOM工廠中獲得DOM解析器
            DocumentBuilder dbBuilder = dbFactory.newDocumentBuilder();
            //創建文檔樹模型對象
            doc = dbBuilder.newDocument();
            if(doc != null){
                //創建school元素
                school = doc.createElement("School");
                //創建student元素
                student = doc.createElement("Student");
                //設置元素Student的屬性值為231
                student.setAttribute("examId", "23");
                //創建名稱為Name的元素
                name = doc.createElement("Name");
                //創建名稱為 香香 的文本節點并作為子節點添加到name元素中
                name.appendChild(doc.createTextNode("香香"));
                //將name子元素添加到student中
                student.appendChild(name);
                /**
                 * 下面的元素依次加入即可
                 * */
                num = doc.createElement("Num");
                num.appendChild(doc.createTextNode("1006010066"));
                student.appendChild(num);
                
                classes = doc.createElement("Classes");
                classes.appendChild(doc.createTextNode("眼視光5"));
                student.appendChild(classes);
                
                address = doc.createElement("Address");
                address.appendChild(doc.createTextNode("浙江溫州"));
                student.appendChild(address);
                
                tel = doc.createElement("Tel");
                tel.appendChild(doc.createTextNode("123890"));
                student.appendChild(tel);
                
                //將student作為子元素添加到樹的根節點school
                school.appendChild(student);
                //添加到文檔樹中
                doc.appendChild(school);
                //將內存中的文檔通過文件流生成insertSchool.xml,XmlDocument位于crison.jar下
                ((XmlDocument)doc).write(new FileOutputStream("src/xidian/sl/dom/createSchool.xml"));
                System.out.println("創建成功");
            }
        }catch (Exception e) {
            // TODO: handle exception
            e.printStackTrace();
        }
    }
    public static void main(String[] args) {
        CreateNewDom.createDom();
    }
}

運行結果:

Java中org.w3c.dom.Document類方法引用報錯怎么辦

DOM的操作應該還是非常簡單明了的,掌握了沒哦。

感謝你能夠認真閱讀完這篇文章,希望小編分享的“Java中org.w3c.dom.Document類方法引用報錯怎么辦”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

平罗县| 杭州市| 大连市| 汾西县| 资兴市| 志丹县| 沙坪坝区| 东兰县| 衡山县| 哈尔滨市| 曲阳县| 革吉县| 广德县| 银川市| 池州市| 新和县| 固阳县| 丰城市| 灵台县| 合肥市| 沂南县| 合江县| 台东市| 繁昌县| 泰兴市| 呼玛县| 乌拉特前旗| 新田县| 文成县| 辽源市| 朝阳区| 石林| 甘孜县| 南溪县| 广饶县| 昌邑市| 武城县| 武安市| 雷山县| 佛教| 天全县|