日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > asp.net >内容正文

asp.net

java w3c xml_org.w3c.dom(java dom)解析XML文档

發布時間:2025/3/8 asp.net 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java w3c xml_org.w3c.dom(java 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對象上進行操作即可;

包含的方法:

4.節點列表類NodeList

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

5.節點類Node

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

6.元素類Element

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

7.屬性類Attr

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

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

實戰:

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

school.xml文檔:

沈浪

1006010022

信管2

浙江杭州3

123456

沈1

1006010033

信管1

浙江杭州4

234567

沈2

1006010044

生工2

浙江杭州1

345678

沈3

1006010055

電子2

浙江杭州2

456789

DomDemo.java

1   packagexidian.sl.dom;2 importjava.io.FileOutputStream;3

4 importjavax.xml.parsers.DocumentBuilder;5 importjavax.xml.parsers.DocumentBuilderFactory;6

7 importorg.apache.crimson.tree.XmlDocument;8 importorg.w3c.dom.Document;9 importorg.w3c.dom.Element;10 importorg.w3c.dom.NodeList;11

12

13 public classDomDemo {14 /**

15 * 遍歷xml文檔16 **/

17 public static voidqueryXml(){18 try{19 //得到DOM解析器的工廠實例

20 DocumentBuilderFactory dbFactory =DocumentBuilderFactory.newInstance();21 //從DOM工廠中獲得DOM解析器

22 DocumentBuilder dbBuilder =dbFactory.newDocumentBuilder();23 //把要解析的xml文檔讀入DOM解析器

24 Document doc = dbBuilder.parse("src/xidian/sl/dom/school.xml");25 System.out.println("處理該文檔的DomImplementation對象 = "+doc.getImplementation());26 //得到文檔名稱為Student的元素的節點列表

27 NodeList nList = doc.getElementsByTagName("Student");28 //遍歷該集合,顯示結合中的元素及其子元素的名字

29 for(int i = 0; i< nList.getLength() ; i ++){30 Element node =(Element)nList.item(i);31 System.out.println("Name: "+ node.getElementsByTagName("Name").item(0).getFirstChild().getNodeValue());32 System.out.println("Num: "+ node.getElementsByTagName("Num").item(0).getFirstChild().getNodeValue());33 System.out.println("Classes: "+ node.getElementsByTagName("Classes").item(0).getFirstChild().getNodeValue());34 System.out.println("Address: "+ node.getElementsByTagName("Address").item(0).getFirstChild().getNodeValue());35 System.out.println("Tel: "+ node.getElementsByTagName("Tel").item(0).getFirstChild().getNodeValue());36 }37

38 }catch(Exception e) {39 //TODO: handle exception

40 e.printStackTrace();41 }42 }43 /**

44 * 向已存在的xml文件中插入元素45 **/

46 public static voidinsertXml(){47 Element school = null;48 Element student = null;49 Element name = null;50 Element num = null;51 Element classes = null;52 Element address = null;53 Element tel = null;54 try{55 //得到DOM解析器的工廠實例

56 DocumentBuilderFactory dbFactory =DocumentBuilderFactory.newInstance();57 //從DOM工廠中獲得DOM解析器

58 DocumentBuilder dbBuilder =dbFactory.newDocumentBuilder();59 //把要解析的xml文檔讀入DOM解析器

60 Document doc = dbBuilder.parse("src/xidian/sl/dom/school.xml");61 //得到文檔名稱為Student的元素的節點列表

62 NodeList nList = doc.getElementsByTagName("School");63 school = (Element)nList.item(0);64 //創建名稱為Student的元素

65 student = doc.createElement("Student");66 //設置元素Student的屬性值為231

67 student.setAttribute("examId", "23");68 //創建名稱為Name的元素

69 name = doc.createElement("Name");70 //創建名稱為 香香 的文本節點并作為子節點添加到name元素中

71 name.appendChild(doc.createTextNode("香香"));72 //將name子元素添加到student中

73 student.appendChild(name);74 /**

75 * 下面的元素依次加入即可76 **/

77 num = doc.createElement("Num");78 num.appendChild(doc.createTextNode("1006010066"));79 student.appendChild(num);80

81 classes = doc.createElement("Classes");82 classes.appendChild(doc.createTextNode("眼視光5"));83 student.appendChild(classes);84

85 address = doc.createElement("Address");86 address.appendChild(doc.createTextNode("浙江溫州"));87 student.appendChild(address);88

89 tel = doc.createElement("Tel");90 tel.appendChild(doc.createTextNode("123890"));91 student.appendChild(tel);92

93 //將student作為子元素添加到樹的根節點school

94 school.appendChild(student);95 //將內存中的文檔通過文件流生成insertSchool.xml,XmlDocument位于crison.jar下

96 ((XmlDocument)doc).write(new FileOutputStream("src/xidian/sl/dom/insertSchool.xml"));97 System.out.println("成功");98 }catch(Exception e) {99 //TODO: handle exception

100 e.printStackTrace();101 }102 }103 public static voidmain(String[] args){104 //讀取

105 DomDemo.queryXml();106 //插入

107 DomDemo.insertXml();108 }109 }110

運行后結果:

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

打開查看內容:

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

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

packagexidian.sl.dom;importjava.io.FileOutputStream;importjavax.xml.parsers.DocumentBuilder;importjavax.xml.parsers.DocumentBuilderFactory;importorg.apache.crimson.tree.XmlDocument;importorg.w3c.dom.Document;importorg.w3c.dom.Element;public classCreateNewDom {/*** 創建xml文檔

**/

public static voidcreateDom(){

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 voidmain(String[] args) {

CreateNewDom.createDom();

}

}

運行結果:

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

總結

以上是生活随笔為你收集整理的java w3c xml_org.w3c.dom(java dom)解析XML文档的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。