java dom解析xml路径_JAVA使用DOM解析XML

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對象上進行操作即可;

包含的方法:

6cdf6fd67fee364878d413d742dc3b5d.png

a055af1de77a381647c672286d2b9e50.png

645e5f82967b6a84177bc7359d520ad7.png

4.節點列表類NodeList

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

875732fe382da9d790f5e416458c953b.png

5.節點類Node

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

6.元素類Element

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

316c5a1a31564e25427d9902d0fc4b96.png

09bec38c91f4e68547f715fb3f92ff32.png

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

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();

}

}

運行后結果:

de5dbeb9e1d5de644b94884f7ecb4fb5.png

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

fb0292a6f3f250d9958cdaa1170402e5.png

打開查看內容:

85dd77fb0d837ac2a15fa863c0a8406f.png

上面添加元素后輸出的文件與之前的文件不是同一個文件,如果需要輸出到原文件中,那么只要將路徑改為原文間路徑即可: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();

}

}

運行結果:

59e6395a1920e14ca4c80099f6ebb2c5.png

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

原文鏈接:http://www.cnblogs.com/shenliang123/archive/2012/05/11/2495252.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值