這篇文章主要介紹了 android中sax怎樣解析xml,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
在萊山等地區(qū),都構建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務理念,為客戶提供成都網(wǎng)站建設、網(wǎng)站建設 網(wǎng)站設計制作按需定制設計,公司網(wǎng)站建設,企業(yè)網(wǎng)站建設,成都品牌網(wǎng)站建設,成都全網(wǎng)營銷,成都外貿(mào)網(wǎng)站建設,萊山網(wǎng)站建設費用合理。
SAX是一個解析速度快并且占用內(nèi)存少的xml解析器,非常適合用于Android等移動設備。 SAX解析XML文件采用的是事件驅(qū)動,也就是說,它并不需要解析完整個文檔,在按內(nèi)容順序解析文檔的過程中,SAX會判斷當前讀到的字符是否合法XML語法中的某部分,如果符合就會觸發(fā)事件。所謂事件,其實就是一些回調(diào)(callback)方法,這些方法(事件)定義在ContentHandler接口。下面是一些ContentHandler接口常用的方法:
startDocument() 當遇到文檔的開頭的時候,調(diào)用這個方法,可以在其中做一些預處理的工作。
endDocument() 和上面的方法相對應,當文檔結(jié)束的時候,調(diào)用這個方法,可以在其中做一些善后的工作。
startElement(String namespaceURI, String localName, String qName, Attributes atts)
當讀到一個開始標簽的時候,會觸發(fā)這個方法。namespaceURI就是命名空間,localName是不帶命名空間前綴的標簽名,qName是帶命名空間前綴的標簽名。通過atts可以得到所有的屬性名和相應的值。要注意的是SAX中一個重要的特點就是它的流式處理,當遇到一個標簽的時候,它并不會紀錄下以前所碰到的標簽,也就是說,在startElement()方法中,所有你所知道的信息,就是標簽的名字和屬性,至于標簽的嵌套結(jié)構,上層標簽的名字,是否有子元屬等等其它與結(jié)構相關的信息,都是不得而知的,都需要你的程序來完成。這使得SAX在編程處理上沒有DOM來得那么方便。
endElement(String uri, String localName, String name) 這個方法和上面的方法相對應,在遇到結(jié)束標簽的時候,調(diào)用這個方法。 characters(char[] ch, int start, int length)
這個方法用來處理在XML文件中讀到的內(nèi)容,第一個參數(shù)為文件的字符串內(nèi)容,后面兩個參數(shù)是讀到的字符串在這個數(shù)組中的起始位置和長度,使用new String(ch,start,length)就可以獲取內(nèi)容。
xml的源文件和android dom 解析xml方式中的xml 文件內(nèi)容相同,可以參照那個文件來解析,只是名稱不同而已,
這個途中圖中有三個saxTest.xml文件,分別對應三種不同的讀取方式
<pre name="code" class="html"> // 讀取類得包下的xml文件 // InputStream inputStream = // this.getClass().getClassLoader().getResourceAsStream("cn/com/sax/saxTest.xml"); //讀取src下xml文件 InputStream inputStream = this.getClass().getClassLoader().getResourceAsStream("saxTest.xml"); // 讀取assets下的xml文件 // InputStream inputStream = this.getAssets().open("saxTest.xml");</pre> <pre></pre> 第一種方式解析xml 主要是繼承DefaultHandler,實現(xiàn)其中的幾個方法 <pre></pre>
下面放出我解析的源碼:
/** * 用sax解析xml的第一種方式 * @return */ private String saxParse(){ SAXParserFactory factory = SAXParserFactory.newInstance(); SAXParser parser; String xmlStr = "第一種解析方式:\n"; try { // 讀取類得包下的xml文件 // InputStream inputStream = // this.getClass().getClassLoader().getResourceAsStream("cn/com/sax/saxTest.xml"); //讀取src下xml文件 InputStream inputStream = this.getClass().getClassLoader().getResourceAsStream("saxTest.xml"); // 讀取assets下的xml文件 // InputStream inputStream = this.getAssets().open("saxTest.xml"); parser = factory.newSAXParser(); SaxParseHandler personHandler = new SaxParseHandler(); parser.parse(inputStream, personHandler); xmlStr = xmlStr + personHandler.parseToString(); } catch (ParserConfigurationException e) { e.printStackTrace(); Log.e("TEST", "" + e.toString()); } catch (SAXException e) { e.printStackTrace(); Log.e("TEST", "" + e.toString()); } catch (IOException e) { e.printStackTrace(); Log.e("TEST", "" + e.toString()); } return xmlStr; }
繼承DefaultHandler處理xml中的元素節(jié)點。
<span style="font-size:13px;">class SaxParseHandler extends DefaultHandler { String result; public String parseToString() { return result; } String str = null; /** * xml開始時,執(zhí)行此函數(shù) */ @Override public void startDocument() throws SAXException { // Log.e("TEST", "startDocument"); } /** * xml結(jié)束時,執(zhí)行此函數(shù) */ @Override public void endDocument() throws SAXException { // Log.e("TEST", "endDocument"); } /** * xml標簽開始時,執(zhí)行此函數(shù),讀取標簽名稱,和標簽內(nèi)的屬性 */ @Override public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException { if ("group".equals(localName)) { String groupName = attributes.getValue(0); String num = attributes.getValue(1); result = result + "groupName=" + groupName + " num =" + num + "\n"; } else if ("person".equals(localName)) { String personName = attributes.getValue(0); String age = attributes.getValue(1); // 和getValue(1)等效 // String txt = attributes.getValue("age"); result = result + "personName" + personName + " age=" + age + "\n"; } else { str = localName; } // Log.e("TEST", "startElement"); } /** * xml標簽結(jié)束時,執(zhí)行此函數(shù) */ @Override public void endElement(String uri, String localName, String qName) throws SAXException { str = null; // Log.e("TEST", "endElement"); } /** * 解析標簽內(nèi)的值,如<chinese>ssss</chinese>,為了讀取"ssss" */ @Override public void characters(char[] ch, int start, int length) throws SAXException { if (str != null) { String data = new String(ch, start, length); //xml文件格式化的時候容易產(chǎn)生以下?lián)Q行,制表符等特殊字符, //這些需要特別注意處理 Pattern p = Pattern.compile("\\s*|\t|\r|\n"); Matcher m = p.matcher(data); data = m.replaceAll(""); if ("chinese".equals(str)) { if(!data.equals("")){ String chinese = data; result = result + "chinese=" + chinese; } } else if ("english".equals(str)) { if(!data.equals("")){ String english = data; result = result + "english=" + english + "\n"; } } } } }</span>
感謝你能夠認真閱讀完這篇文章,希望小編分享的“ android中sax怎樣解析xml”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián),關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關知識等著你來學習!
分享文章:android中sax怎樣解析xml
路徑分享:http://m.2m8n56k.cn/article28/gioscp.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供App設計、網(wǎng)站導航、關鍵詞優(yōu)化、網(wǎng)站內(nèi)鏈、電子商務、做網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:[email protected]。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)