国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

XML解析詳解|樂(lè)字節(jié)

LinkedME2016 / 1532人閱讀

摘要:解析獲取解析器獲取文檔獲取根節(jié)點(diǎn)獲取根節(jié)點(diǎn)下所有的子節(jié)點(diǎn),也可以根據(jù)標(biāo)簽名稱獲取指定的直接點(diǎn)獲取元素的名稱和里面的文本創(chuàng)建創(chuàng)建節(jié)點(diǎn)創(chuàng)建屬性設(shè)置文本設(shè)置關(guān)系關(guān)于解析先講到這里了,請(qǐng)繼續(xù)關(guān)注樂(lè)字節(jié),后續(xù)超級(jí)干貨奉上,快快樂(lè)樂(lè)學(xué)。

大家好,樂(lè)字節(jié)的小樂(lè)又來(lái)了,Java技術(shù)分享哪里少的了小樂(lè)!上次我們說(shuō)了可擴(kuò)展標(biāo)記語(yǔ)言XML之二:XML語(yǔ)言格式規(guī)范、文檔組成,本文將介紹重點(diǎn)——XML解析。

基本的解析方式有兩種:一種叫 SAX,另一種叫 DOM。

SAX(Simple API for XML)是基于 事件流的解析,DOM(Document Object Model)是基于 XML 文檔樹結(jié)構(gòu)的解析。SAX:效 率高,數(shù)據(jù)量小,僅一次獲取 。

DOM:整顆樹加載到內(nèi)存中,耗內(nèi)存,可多次獲取。

一、DOM 解析

與 js 中的類似,使用 JAXP(Java API for XML Parsing),即:用于 XML 解析的 Java API.

DOM(Document Object Model, 文檔對(duì)象模型),在應(yīng)用程序中,基于 DOM 的 XML

分析器將一個(gè) XML 文檔轉(zhuǎn)換成一個(gè)對(duì)象模型的集合(通常稱為 DOM 樹),應(yīng)用程序正是通過(guò)對(duì)這個(gè)對(duì)象模型的操作,來(lái)實(shí)現(xiàn)對(duì) XML 文檔數(shù)據(jù)的操作。

XML 本身是以樹狀的形式出現(xiàn)的,所以 DOM 操作的時(shí)候,也將按章樹的形式進(jìn)行轉(zhuǎn)換。 在整個(gè) DOM 樹種,最大的地方指的是 Document,表示一個(gè)文檔,在這個(gè)文檔中存在一個(gè)根節(jié)點(diǎn)。

注意:在使用 DOM 操作的時(shí)候,每一個(gè)文字的區(qū)域也是一個(gè)節(jié)點(diǎn),稱為文本節(jié)點(diǎn)。

1、核心操作接口

在 DOM 解析中有以下四個(gè)核心的操作接口

Document : 此接口代表了整個(gè) XML 文檔,表示的是整棵 DOM 樹的根,提供了對(duì)文檔中的數(shù)據(jù)進(jìn)行訪問(wèn)和操作的入口,通過(guò) Document 節(jié)點(diǎn)可以訪問(wèn) XML 文件中所有的元素內(nèi)容。

Node : 此接口在整個(gè) DOM 樹種具有舉足輕重的低位,DOM 操作的核心接口中有很大 一部分接口是從 Node 接口繼承過(guò)來(lái)的。例如:Document、Element 等接口,在 DOM 樹種,每一個(gè) Node 接口代表了 DOM 樹種的一個(gè)節(jié)點(diǎn)。

NodeList : 此接口表示的是一個(gè)節(jié)點(diǎn)的集合,一般用于表示有順序關(guān)系的一組節(jié)點(diǎn),

例如:一個(gè)節(jié)點(diǎn)的子節(jié)點(diǎn),當(dāng)文檔改變的時(shí)候會(huì)直接影響到 NodeList 集合。

NamedNodeMap : 此接口表示的是一組節(jié)點(diǎn)和其唯一名字對(duì)應(yīng)的一一對(duì)應(yīng)關(guān)系,本

接口主要用于屬性節(jié)點(diǎn)的表示上。

2、DOM 解析過(guò)程

如果一個(gè)程序需要進(jìn)行 DOM 解析讀取操作的話,也需要按照如下的步驟進(jìn)行:

① 建 立 DocumentBuilderFactory : DocumentBuilderFactory factory =

DocumentBuilderFactory.newInstance();

②建立 DocumentBuilder: DocumentBuilder builder = factory.newDocumentBuilder();

③建立 Document : Document doc = builder.parse(“要解析的文件路徑”);

④建立 NodeList : NodeList nl = doc.getElementsByTagName(“讀取節(jié)點(diǎn)”);

⑤進(jìn)行 XML 信息讀取

DOM 操作除了可以進(jìn)行解析外,也可以進(jìn)行文檔的生成

如果想要生成 XML 文件,則在創(chuàng)建文檔的時(shí)候,就應(yīng)該使用 newDocument()方法

如果要將 DOM 的文檔輸出,本身是比較麻煩的 。一次編寫多次 copy

public static void createXml() throws Exception{ 
//獲取解析器工廠 
DocumentBuilderFactory factory=DocumentBuilderFactory.newInstance(); 
//獲取解析器 
DocumentBuilder builder=factory.newDocumentBuilder(); 
//創(chuàng)建文檔 
Document doc=builder.newDocument(); 
//創(chuàng)建元素、設(shè)置關(guān)系 
Element root=doc.createElement("people"); 
Element person=doc.createElement("person"); 
Element name=doc.createElement("name"); 
Element age=doc.createElement("age"); 
name.appendChild(doc.createTextNode("shsxt")); 
age.appendChild(doc.createTextNode("10")); 
doc.appendChild(root); 
root.appendChild(person); 
person.appendChild(name); 
person.appendChild(age); 
//寫出去 
// 獲得變壓器工廠 
TransformerFactory tsf=TransformerFactory.newInstance(); 
Transformer ts=tsf.newTransformer(); 
//設(shè)置編碼
ts.setOutputProperty(OutputKeys.ENCODING, "UTF-8"); 
//創(chuàng)建帶有DOM節(jié)點(diǎn)的新輸入源,充當(dāng)轉(zhuǎn)換Source樹的持有者 
DOMSource source=new DOMSource(doc); 
//充當(dāng)轉(zhuǎn)換結(jié)果的持有者 
File file=new File("src/output.xml"); 
StreamResult result=new StreamResult(file); 
ts.transform(source, result); 
}
二、SAX 解析

SAX(Simple API for XML)解析是按照 xml 文件的順序一步一步的來(lái)解析。SAX 沒(méi)有官方 的標(biāo)準(zhǔn)機(jī)構(gòu),它不屬于任何標(biāo)準(zhǔn)阻止或團(tuán)體,也不屬于任何公司或個(gè)人,而是提供任何 人使用的一種計(jì)算機(jī)技術(shù)。

SAX(Simple API for XML,操作 XML 的簡(jiǎn)單接口),與 DOM 操作不同的是,SAX 采用的 是一種順序的模式進(jìn)行訪問(wèn),是一種快速讀取 XML 數(shù)據(jù)的方式。當(dāng)使用 SAX 解析器進(jìn)行操作的時(shí)候會(huì)觸發(fā)一系列的事情,當(dāng)掃描到文檔(document)開始與結(jié)束、元素 (element)開始與結(jié)束時(shí)都會(huì)調(diào)用相關(guān)的處理方法,并由這些操作方法作出相應(yīng)的操 作,直至整個(gè)文檔掃描結(jié)束。

如果要想實(shí)現(xiàn)這種 SAX 解析,則肯定首先建立一個(gè) SAX 的解析器

// 1、創(chuàng)建解析器工廠 
SAXParserFactory factory = SAXParserFactory.newInstance(); 
// 2、獲得解析器 
SAXParser parser = factory.newSAXParser(); 
// SAX解析器 ,繼承 DefaultHandler 
String path = new File("resource/demo01.xml").getAbsolutePath(); 
// 解析 
parser.parse(path, new MySaxHandler()); 
三、DOM4j 解析

dom4j 是一個(gè)簡(jiǎn)單的開源庫(kù),用于處理 XML、 XPath 和 XSLT,它基于 Java 平臺(tái),使用 Java 的集合框架,全面集成了 DOM,SAX 和 JAXP。下載路徑:

http://www.dom4j.org/dom4j-1....

http://sourceforge.net/projec...

可以使用 DOM4J 進(jìn)行 XML 文件的讀、寫操作

DOM4J 與 JDOM 一樣都屬于一個(gè)免費(fèi)的 XML 開源組建,但是由于現(xiàn)在的開發(fā)框架中使 用該技術(shù)較多,比如 Hibernate、Spring 等都使用 DOM4J 這個(gè)功能,所以作為介紹, 大家可以對(duì)該組件有一個(gè)了解。并沒(méi)有誰(shuí)好誰(shuí)壞,一般框架使用 DOM4J 較多,而我們平時(shí)如果要用則 JDOM 較常見。 可以發(fā)現(xiàn) DOM4J 發(fā)揮了很多新特性,比如輸出格式就可以很好解析。

File file = new File("resource/outputdom4j.xml"); 
SAXReader reader = new SAXReader(); 
// 讀取文件作為文檔 
Document doc = reader.read(file); 
// 獲取文檔的根元素 
Element root = doc.getRootElement(); 
// 根據(jù)跟元素找到全部的子節(jié)點(diǎn) 
Iterator iter = root.elementIterator(); 
while(iter.hasNext()){ 
Element name = iter.next(); 
System.out.println("value = " + name.getText()); 
} 

創(chuàng)建

// 使用DocumentHelper來(lái)創(chuàng)建 Document對(duì)象 
Document document = DocumentHelper.createDocument(); 
// 創(chuàng)建元素并設(shè)置關(guān)系 
Element person = document.addElement("person"); 
Element name = person.addElement("name"); 
Element age = person.addElement("age"); 
// 設(shè)置文本 
name.setText("shsxt"); 
age.setText("10"); 
// 創(chuàng)建格式化輸出器 
OutputFormat of = OutputFormat.createPrettyPrint(); 
of.setEncoding("utf-8"); 
// 輸出到文件 
File file = new File("resource/outputdom4j.xml"); 
XMLWriter writer = new XMLWriter(new FileOutputStream(new 
File(file.getAbsolutePath())),of); 
// 寫出 
writer.write(document); 
writer.flush(); 
writer.close(); 

四、JDOM 解析

下載路徑: http://www.jdom.org/downloads...

JDOM 是一種使用 XML 的獨(dú)特 Java 工具包,用于快速開發(fā) XML 應(yīng)用程序。JDOM 是一個(gè)開源項(xiàng)目,它基于樹形結(jié)構(gòu),利用純 Java 的技術(shù)對(duì) XML 文檔實(shí)現(xiàn)解析、生成、序列 化及多種操作。

JDOM 解析

掌握 JDOM 開發(fā)工具的使用及產(chǎn)生原理

可以使用 JDOM 進(jìn)行讀取或?qū)懭氲牟僮?/p>

在 W3C 本身提供的 XML 操作標(biāo)準(zhǔn),DOM 和 SAX,但是從開發(fā)角度上看,DOM 和 SAX

本身是各有特點(diǎn)的,DOM 可以修改,但不適合讀取大文件,而 SAX 可以讀取大文件,

但是本身不能修改所謂的 JDOM = DOM 的可修改 + SAX 的讀取大文件 。

JDOM 本身是一個(gè)免費(fèi)的開源組建,直接從 http://www.jdom.org 上下載 ,下載后解壓,將 jdom.jar 包拷貝到 Tomcat 目錄(項(xiàng)目)的 lib 中 。

JDOM 主要操作的類:

我們發(fā)現(xiàn) JDOM 的輸出操作要比傳統(tǒng)的 DOM 方便得多,而且也更加直觀,包括在輸出

的時(shí)候都很容易了。

此時(shí)觀察到的是 JDOM 對(duì)于 DOM 解析的支持,但是也說(shuō),JDOM 本身也支持了 SAX 的

特點(diǎn);所以,可以使用 SAX 進(jìn)行解析操作。

解析

// 獲取SAX解析器 
SAXBuilder builder = new SAXBuilder(); 
File file = new File("resource/demo01.xml"); 
// 獲取文檔 
Document doc = builder.build(new File(file.getAbsolutePath())); 
// 獲取根節(jié)點(diǎn) 
Element root = doc.getRootElement(); 
System.out.println(root.getName()); 
// 獲取根節(jié)點(diǎn)下所有的子節(jié)點(diǎn), 也可以根據(jù)標(biāo)簽名稱獲取指定的直接點(diǎn) 
List list = root.getChildren(); 
System.out.println(list.size()); 
for(int x = 0; x

創(chuàng)建

// 創(chuàng)建節(jié)點(diǎn) 
Element person = new Element("person"); 
Element name = new Element("name"); 
Element age = new Element("age"); 
// 創(chuàng)建屬性 
Attribute id = new Attribute("id","1"); 
// 設(shè)置文本 
name.setText("shsxt"); 
age.setText("10"); 
// 設(shè)置關(guān)系 
Document doc = new Document(person); 
person.addContent(name); 
name.setAttribute(id); 
person.addContent(age); 
XMLOutputter out = new XMLOutputter(); 
File file = new File("resource/outputjdom.xml"); 
out.output(doc, new FileOutputStream(file.getAbsoluteFile()));

關(guān)于XML解析先講到這里了,請(qǐng)繼續(xù)關(guān)注樂(lè)字節(jié),后續(xù)Java超級(jí)干貨奉上,快快樂(lè)樂(lè)學(xué)Java。

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/110395.html

相關(guān)文章

  • 可擴(kuò)展標(biāo)記語(yǔ)言XML之一:XML的概念、作用與示例

    摘要:當(dāng)今廣泛使用的標(biāo)記語(yǔ)言是超文本標(biāo)記語(yǔ)言,和可擴(kuò)展標(biāo)記語(yǔ)言。標(biāo)記語(yǔ)言廣泛應(yīng)用于網(wǎng)頁(yè)和網(wǎng)絡(luò)應(yīng)用程序。羋月與楚公子黃歇青梅竹馬,真心相愛,但被作為嫡公主羋姝的陪嫁媵侍遠(yuǎn)嫁秦國(guó)。目前只有一個(gè)版本,即是自描述數(shù)據(jù),使用現(xiàn)有的國(guó)際標(biāo)準(zhǔn)。 哈嘍大家好啊,樂(lè)字節(jié)小樂(lè)又來(lái)給大家分享Java技術(shù)文章了。上次已經(jīng)講完了Java多線程相關(guān)知識(shí),這次文章將講述可擴(kuò)展標(biāo)記語(yǔ)言XMLshowImg(https://...

    myshell 評(píng)論0 收藏0
  • 可擴(kuò)展標(biāo)記語(yǔ)言XML之一:XML的概念、作用與示例

    摘要:當(dāng)今廣泛使用的標(biāo)記語(yǔ)言是超文本標(biāo)記語(yǔ)言,和可擴(kuò)展標(biāo)記語(yǔ)言。標(biāo)記語(yǔ)言廣泛應(yīng)用于網(wǎng)頁(yè)和網(wǎng)絡(luò)應(yīng)用程序。羋月與楚公子黃歇青梅竹馬,真心相愛,但被作為嫡公主羋姝的陪嫁媵侍遠(yuǎn)嫁秦國(guó)。目前只有一個(gè)版本,即是自描述數(shù)據(jù),使用現(xiàn)有的國(guó)際標(biāo)準(zhǔn)。 哈嘍大家好啊,樂(lè)字節(jié)小樂(lè)又來(lái)給大家分享Java技術(shù)文章了。上次已經(jīng)講完了Java多線程相關(guān)知識(shí),這次文章將講述可擴(kuò)展標(biāo)記語(yǔ)言XMLshowImg(https://...

    william 評(píng)論0 收藏0
  • 樂(lè)字節(jié)-Java8新特性之Date API

    摘要:上一篇文章,小樂(lè)給大家?guī)?lái)了新特性之,接下來(lái)本文將會(huì)給大家介紹新特性之前言通過(guò)發(fā)布新的來(lái)進(jìn)一步加強(qiáng)對(duì)日期與時(shí)間的處理。 上一篇文章,小樂(lè)給大家?guī)?lái)了Java8新特性之Optional,接下來(lái)本文將會(huì)給大家介紹Java8新特性之Date API 前言: Java 8通過(guò)發(fā)布新的Date-Time API來(lái)進(jìn)一步加強(qiáng)對(duì)日期與時(shí)間的處理。 舊版的 Java 中,日期時(shí)間 API 存在諸多問(wèn)題...

    suemi 評(píng)論0 收藏0
  • 樂(lè)字節(jié)Java繼承-方法重寫、super和final關(guān)鍵字

    摘要:大家好,樂(lè)字節(jié)的小樂(lè)又來(lái)了,上一篇是樂(lè)字節(jié)繼承與權(quán)限修飾,也是屬于繼承的,今天繼續(xù)繼承方法重寫和關(guān)鍵字。三關(guān)鍵字表示最終的。修飾類,表示該類不能被繼承修飾方法,表示該方法不能被重寫修飾屬性,表示常量,值一旦確定不可改變。 大家好,樂(lè)字節(jié)的小樂(lè)又來(lái)了,上一篇是:樂(lè)字節(jié)Java|JavaBean、繼承與權(quán)限修飾,也是屬于Java繼承的,今天繼續(xù)Java繼承-方法重寫、super和final...

    trigkit4 評(píng)論0 收藏0
  • 樂(lè)字節(jié)Java|this關(guān)鍵字、static關(guān)鍵字、block塊

    摘要:在成員方法中或構(gòu)造器中隱式的傳遞。作用如下在構(gòu)造器中只能放在第一行屬性避免屬性和形參局部變量同名,發(fā)生就近原則實(shí)參列表構(gòu)造器的首行調(diào)用其他構(gòu)造器。關(guān)鍵字靜態(tài)的公共的。構(gòu)造塊,先于構(gòu)造器執(zhí)行,每創(chuàng)建一個(gè)對(duì)象執(zhí)行一次。 大家好,我是樂(lè)字節(jié)的小樂(lè),從本文開始將會(huì)給大家講述Java繼承,一下是Java繼承的知識(shí)圖譜:showImg(https://segmentfault.com/img/bV...

    _DangJin 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<