搜尋
首頁後端開發XML/RSS教程Android中的xml解析

Android中的xml解析

Apr 04, 2017 am 10:55 AM
xml解析

一、緒論

        上週工作需要了解專案的一些大體內容,結果在xml解析這一塊看的迷迷糊糊的,所以在這裡把學習到xml解析的一些知識記錄一下。

二、解析   

        android 中的xml解析器主要有三種,DOM解析器、SAX解析器和pull解析器。 ##Document

Object Model

) 是 XML文檔的

物件模型,可用來直接存取XML文檔的各個部分。解析大文檔時不建議使用DOM解析。 。對XML文件進行操作時,首先要解析文件,將文件分為獨立的元素、屬性註釋等,然後以節點樹的形式在記憶體中對XML文件進行表示,就可以透過節點樹存取文件的內容,並根據需要修改文件。介面定義分析並建立DOM文件的一系列方法,它是文件樹的根,是操作DOM的基礎。方法。 ##:提供獲得節點個數和目前節點的方法。

2、SAX解析        SAX(Simple API

for

XML)使用串流處理的方式,它不會記錄所讀內容的相關資訊。使用回呼函數來實現。 缺點是因為以事件為驅動的它不能回退。

        它的核心是

事件處理模式,主要是圍繞著事件來源以及事件處理器來運作的。當事件來源產生事件後,呼叫事件處理器對應的處理方法,一個事件就可以處理。在事件源呼叫事件處理器中特定方法的時候,也要傳遞給事件處理器對應事件的狀態訊息,這樣事件處理器才能夠根據提供的事件資訊來決定自己的行為

        SAX的工作原理:SAX會順序掃描文檔,在掃描到文檔(document)開始與結束、元素(element)開始與結束、元素內容(characters)等時通知事件處理方法,事件處理方法進行相應處理,然後繼續掃描,指導文件掃描結束。         常用的SAX介面與類別:


#Attrbutes:用來取得屬性的數量、名字、值。

ContentHandler:定義與文件本身關聯的事件(例如,開始和結束標記)。大多數應用程式都註冊這些事件。

DTDHandler:定義與DTD關聯的事件。它沒有定義足夠的事件來完整地報告DTD。如果需要對DTD進行語法分析,請使用可選的DeclHandler。

DeclHandler是SAX的擴充。不是所有的語法分析器都支援它。

EntityResolver:定義與裝入實體關聯的事件。只有少數幾個應用程式註冊這些事件。

ErrorHandler:定義錯誤事件。許多應用程式註冊這些事件以便用它們自己的方式報錯。

DefaultHandler:它提供了這些接LI的預設實作。在大多數情況下,為應用程式擴展DefaultHandler並覆蓋相關的方法要比直接實作一個介面更容易。

         以下是部分說明:

Android中的xml解析

SAX處理器說明


Android中的xml解析



部分常用方法說明

        所以,我們通常要使用XmlReader和DefaultHandler配合起來解析xml文件。

        SAX的解析流程:

startDocument --> startElement --> characters -->

endElement --> endDocument


#3、pull解析

        Pull內建於Android系統。也是官方解析佈局文件所使用的方式。 Pull與SAX有點類似,都提供了類似的事件,例如起始元素和結束元素。不同的是,SAX的事件驅動是回呼對應方法,需要提供回呼的方法,而後來在SAX內部自動呼叫對應的方法。而Pull解析器並沒有強制要求提供觸發的方法。因為他觸發的事件不是一個方法,而是一個數字。它使用方便,效率高。 Android官方推薦開發者使用Pull解析技術。 Pull解析技術是第三方開發的開源技術,它同樣可以應用於JavaSE開發。

        pull回傳的

常數

讀取到xml的宣告回傳START_DOCUMENT;

#讀取到xml的結束回傳END_DOCUMENT ;

讀取到xml的開始標籤回傳START_TAG;


讀取到xml的結束標籤回傳END_TAG;

讀取到xml的文字回傳TEXT;         pull的工作原理:pull提供了開始元素和結束元素。當某個元素開始時,我們可以呼叫parser.

next

Text從XML文件中擷取所有字元資料。當解釋到一個文件結束時,自動產生EndDocument事件。

        常用的XML pull的介面和類別:

XmlPullParser:XML pull解析器是一個在XMLPULL VlAP1中提供了定義解析功能的介面。

XmlSerializer:它是一個接口,定義了XML資訊集的序列。

XmlPullParserFactory:這個類別用於在XMPULL V1 API中建立XML Pull解析器。

XmlPullParserException

:拋出單一的XML pull解析器相關的錯誤。

        pull的解析流程:

start_document --> end_document --> start_tag -->end_tag


########################################################################################################################################################################################################### #在Android中還有第四種方式:android.util.Xml類 ###(本人未使用過)######        在Android API中,另外提供了Android. util. Xml類,同樣可以解析XML文件,使用方法類似SAX,也都需編寫Handler來處理XML的解析,但是在使用上卻比SAX來得簡單 ,如下所示:######        以android. util. XML實作XML解析 :######MyHandler myHandler=new MyHandler0;######android. util. Xm1. parse(url.openC0nnection().getlnputStream(),Xml.Encoding.UTF-8,myHandler);#################三、實作####### ###        1、先建立一個參考xml文檔 (放在了as###set###s目錄中)##############################    #### ##        ###

                           靈渠在廣西壯族自治區興安縣境內,是世界上最古老的運河之一,並擁有「世界古代水利建築明珠」的美譽。靈渠古稱秦鑿渠、零渠、陡河、興安運河,於西元前214年鑿成通航,距今已2217年,仍發揮功用。

           

         

       lt;imageurl>

  9aa8fdb7b8322e08244d3c.jpg

            

   

    0">

           

                         200公里,流域面積達5400平方公里,南北貫穿山東半島,溝通黃渤兩海。膠萊運河自平度姚家村東的分水嶺南北分流。南流由麻灣口入膠州灣,為南膠萊河,長30公里。北流由海倉口入萊州灣,為北膠萊河,長100餘公里。

           


           

# com/baike/pic/item/389aa8fdb7b8322e08244d3c.jpg

#             

   

    #String name;// 名稱

Integer length;// 長度

String introduction;// 介紹

#String Imageurl ;// 圖片

url

public String getName() {

#return

name;

}

public void setName(String name) {

this.name = name;

}

public Integer getLength() {

#return length;

}

public void setLength(Integer length) {

this.length = length;

}

#public String getIntroduction() {

return introduction;

}

public void setIntroduction(String introduction) {

this.introduction = introduction;

}

public String getImageurl() {

return Imageurl;

}

public void setImageurl(String imageurl) {

#Imageurl = imageurl;

}

@Override

public String toString() {

return "River [name=" + name + ", length=" + length + ", introduction="

+ introduction + ", Imageurl=" + Imageurl + "]";

}

##}

採用DOM解析時具體處理步驟為:


#1 先利用DocumentBuilderFactory建立一個DocumentBuilderFactory實例

2然後利用DocumentBuilderFactory創建DocumentBuilder
3 然後載入XML文件(Document),

4 然後取得文件的根結點(Element),

5 然後取得根結點中所有子節點的清單(NodeList),

6 然後使用再取得子節點清單中的需要讀取的結點。


下面我們就開始讀取xml文檔對象,並且加入List:

程式碼如下: 我們這裡是使用assets中的river.xml文件,那就需要讀取這個xml文件,回傳輸入流。 讀取方法為:inputStream=this.context.getResources().getAssets().open(fileName); 參數是xml檔案路徑,當然預設的是assets目錄為根目錄。

接著可以用DocumentBuilder物件的parse方法解析輸入流,並傳回document對象,然後再遍歷doument物件的節點屬性。


/**     * DOM解析xml方法    

 * @param filePath    

 * @return    

## * @return    

## * @return    # */    

private ListDOMfromXML(String filePath) {        

#4 ##Listlist = new ArrayList();

DocumentBuilderFactory factory =

null

;

DocumentBuilder builder = null;

Document document = null ;

InputStream inputStream = null;//建構解析器

factory = DocumentBuilderFactory.newInstance();

#try {

builder = factory.newDocumentBuilder();

//找到xml檔案並且載入

inputStream = this.getResources().getAssets().open(filePath);//getAssets後預設根目錄為assets

document = builder.parse(inputStream);

//找到根Element

Element root=document.getDocumentElement();

#NodeList nodes=root.

getElementsByTagName

(RIVER);

//遍歷根節點所有子節點,rivers 下所有river

River river = null;

for (int i = 0; i

river = new River();

//取得river元素節點

Element riverElement = (Element) nodes.item(i);

//設定river中name和length屬性值

river.setName(riverElement.getAttribute("name") );

river.setLength(Integer.parseInt(riverElement.getAttribute("length")));

//取得子標籤Element introduction = (Element) riverElement.getElementsByTagName(INTRODUCTION).item(0);

#Element imageurl = (Element) riverElement.getElementsByTagName(IMAGEURL).item(0);

//設定introduction和imageurl屬性

river.setIntroduction(introduction.getFirstChild().getNodeValue());

river.setImageurl(imageurl.getFirstChild().getNodeValue());

#list.add (river);

}

} catch (ParserConfigurationException e) {

// TODO Auto-generated catch block

e.

print

StackTrace();

} catch (IOException e) {

#// TODO Auto-generated catch block

e.printStackTrace();


} catch (SAXException e) {

// TODO Auto-generated catch blockAndroid中的xml解析
e.printStackTrace();

##}

for ( River river : list) {


Log.w("DOM Test", river.toString());

}return list;

# }

在這裡加入到List中, 然後我們使用log將他們列印出來。如圖所示:

XML解析結果

##以SAX解析時具體處理步驟是:

1 建立SAXParserFactory物件

2 根據SAXParserFactory.newSAXParser()方法傳回一個SAXParser解析器

3 根據SAXParser解析器取得事件來源物件XMLReader

4 實例化一個DefaultHandler物件

5 連結事件來源物件XMLReader到事件處理類別DefaultHandler中

6 呼叫XMLReader的parse方法從輸入來源中取得到的xml資料

7 透過DefaultHandler傳回我們需要的

資料集

合。


程式碼如下:

/**    

 * SAX解析xml    

 * @param filePath    

 * @return    

# */    

##/**&*/    

private ListSAXfromXML(String filePath) {        

ArrayListlist = new ArrayList();

//建構解析器

SAXParserFactory factory = SAXParserFactory.newInstance();

SAXParser parser = null;

XMLReader xReader = null;

try {######parser = factory.newSAXParser();######//取得資料來源######xReader = parser.getXMLReader();######//設定處理器######RiverHandler handler = new RiverHandler();######xReader.setContentHandler(handler);###### //解析xml檔######xReader.parse(new InputSource(this.getAssets().open(filePath)));######list = handler.getList();##### #} catch (ParserConfigurationException e) {###

e.printStackTrace();

} catch (SAXException e) {

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

}

for (River River : list) {

Log.w("DOM Test", River.toString() );

}

返回清單;

}

以上是Android中的xml解析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
RSS文檔格式:探索RSS 2.0及以後RSS文檔格式:探索RSS 2.0及以後Apr 26, 2025 am 12:22 AM

RSS2.0是一種開放標準,允許內容髮布者以結構化的方式分發內容。它包含了豐富的元數據,如標題、鏈接、描述、發布日期等,使得訂閱者能夠快速瀏覽和訪問內容。 RSS2.0的優勢在於其簡潔和擴展性。例如,它允許自定義元素,這意味著開發者可以根據需求添加額外的信息,如作者、分類等。

理解RSS:XML觀點理解RSS:XML觀點Apr 25, 2025 am 12:14 AM

RSS是一種基於XML的格式,用於發布經常更新的內容。 1.RSSfeed通過XML結構化組織信息,包括標題、鏈接、描述等。 2.創建RSSfeed需按照XML結構編寫,添加元數據如語言和發布日期。 3.高級用法可包含多媒體文件和分類信息。 4.調試時使用XML驗證工具,確保必需元素存在且編碼正確。 5.優化RSSfeed可通過分頁、緩存和保持結構簡潔來實現。通過理解和應用這些知識,可以有效管理和分發內容。

XML中的RSS:解碼標籤,屬性和結構XML中的RSS:解碼標籤,屬性和結構Apr 24, 2025 am 12:09 AM

RSS是一種基於XML的格式,用於發布和訂閱內容。 RSS文件的XML結構包括根元素、元素和多個元素,每個代表一個內容條目。通過XML解析器讀取和解析RSS文件,用戶可以訂閱並獲取最新內容。

XML在RSS中的優勢:技術深度潛水XML在RSS中的優勢:技術深度潛水Apr 23, 2025 am 12:02 AM

XML在RSS中具有結構化數據、可擴展性、跨平台兼容性和解析驗證的優勢。 1)結構化數據確保內容的一致性和可靠性;2)可擴展性允許添加自定義標籤以適應內容需求;3)跨平台兼容性使其在不同設備上無縫工作;4)解析和驗證工具確保Feed的質量和完整性。

XML中的RSS:揭示內容聯合的核心XML中的RSS:揭示內容聯合的核心Apr 22, 2025 am 12:08 AM

RSS在XML中的實現方式是通過結構化的XML格式來組織內容。 1)RSS使用XML作為數據交換格式,包含頻道信息和項目列表等元素。 2)生成RSS文件需按規範組織內容,發佈到服務器供訂閱。 3)RSS文件可通過閱讀器或插件訂閱,實現內容自動更新。

超越基礎:高級RSS文檔功能超越基礎:高級RSS文檔功能Apr 21, 2025 am 12:03 AM

RSS的高級功能包括內容命名空間、擴展模塊和條件訂閱。 1)內容命名空間擴展RSS功能,2)擴展模塊如DublinCore或iTunes添加元數據,3)條件訂閱根據特定條件篩選條目。這些功能通過添加XML元素和屬性實現,提升信息獲取效率。

XML主鏈:RSS提要如何結構XML主鏈:RSS提要如何結構Apr 20, 2025 am 12:02 AM

RSSFEEDSUSEXMLTOSSTRUCTURECONTUPDATE.1)XMLPROVIDEDIDESAHIERARCHICALSTRUCTUREFFORDATA.2)THEELEMENTDEFINESTHEEFEED'SIDENTITYANDCONTAINS ELEMENT.3)ELEMENTEMERPREPRESERPRESENTERPRESENTIVIDIVIVELPIECTUALPIECES.4)RSSSSSSSSSSSISEXTEXTENSIBLERECTICERSINCREECTINCERINCTICENT.5)

RSS和XML:了解Web內容的動態二重奏RSS和XML:了解Web內容的動態二重奏Apr 19, 2025 am 12:03 AM

RSS和XML是用於網絡內容管理的工具。 RSS用於發布和訂閱內容,XML用於存儲和傳輸數據。它們的工作原理包括內容髮布、訂閱和更新推送。使用示例包括RSS發布博客文章和XML存儲書籍信息。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。