真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網站制作重慶分公司

androidxml文件,Androidxml

Android XML文件中的@、?、@+的意義

Android XML文件中的@、?、@+的意義

創(chuàng)新互聯(lián)秉承實現(xiàn)全網價值營銷的理念,以專業(yè)定制企業(yè)官網,網站建設、成都網站制作,微信小程序定制開發(fā),網頁設計制作,手機網站制作設計,全網營銷推廣幫助傳統(tǒng)企業(yè)實現(xiàn)“互聯(lián)網+”轉型升級專業(yè)定制企業(yè)官網,公司注重人才、技術和管理,匯聚了一批優(yōu)秀的互聯(lián)網技術人才,對客戶都以感恩的心態(tài)奉獻自己的專業(yè)和所長。

在android開發(fā)中,資源文件里總是會出現(xiàn)

"@string/hello"、“@android:color/darker_gray”、"@+id/title"、"?android:attr/textAppearanceSmall",那么這些究竟有什么不同呢?其實這些都是對資源的引用。

1、首先來看這種,@string/hello,這個的語法是:@[:]/,其中包名是可選的,代表資源是你自己這個包中的,如下圖中的例子

2、然后是“@android:color/darker_gray”,與上一個相比,它多了”android:“,語法是相同的.,它代表引用的是系統(tǒng)資源。

3、"@+id/title",多了個加號,代表引用或創(chuàng)建,若不存在,則創(chuàng)建,若存在,則引用。

4、"?android:attr/textAppearanceSmall",語法是?[:][/],代表引用的是主題中的樣式屬性資源。

5、步驟四中的資源類型是可以省略的??梢赃@樣寫:?android:textAppearanceSmall ;

android中怎么解析復雜的xml文件

本文主要講解Android開發(fā)中如何對XML文件的解析,由于XML文件具有與平臺無關,廣泛應用于數(shù)據(jù)通信中,因此解析XML文件就顯得很有意義。Android對XML文件解析的方法主要有3種。 通常有三種方式:DOM、SAX和PULL,下面就分別針對這三種方式來進行討論。

文件內容如下所示:

那么就是要對此XML文件做解析。下面我們就分別用DOM,SAX和PULL三種方式,分別對此XML文件做解析。

DOM方式

DOM方式解析xml是先把xml文檔都讀到內存中,然后再用DOM API來訪問樹形結構,并獲取數(shù)據(jù)。由DOM解析的方式可以知道,如果XML文件很大的時候,處理效率就會變得比較低,這也是DOM方式的一個缺點。

現(xiàn)在我們來解析上文中提到的有關天氣預報信息相關的xml文件。什么是解析呢?說的通俗一點,就是將這個帶標簽的XML文件識別出來,并抽取一些相關的,對我們有用的信息來給我們使用。那在這個文件里,時間,天氣,溫度,以及圖標對我們來說是需要得到的。我們要對其做解析。

解析的具體思路是:

1. 將XML文件加載進來。

2. 獲取文檔的根節(jié)點

3. 獲取文檔根節(jié)點中所有子節(jié)點的列表

4. 獲取子節(jié)點列表中需要讀取的節(jié)點信息

根據(jù)這4個步驟,我們進行開發(fā):

首先就是如何加載XML文件,假設此文件來源于網絡。

SAX方式

SAX是Simple API for XML的縮寫。是一個包也可以看成是一些接口。

相比于DOM而言SAX是一種速度更快,更有效,占用內存更少的解析XML文件的方法。它是逐行掃描,可以做到邊掃描邊解析,因此SAX可以在解析文檔的任意時刻停止解析。非常適用于Android等移動設備。

SAX是基于事件驅動的。所謂事件驅動就是說,它不用解析完整個文檔,在按內容順序解析文檔過程中,SAX會判斷當前讀到的字符是否符合XML文件語法中的某部分。如果符合某部分,則會觸發(fā)事件。所謂觸發(fā)事件,就是調用一些回調方法。當然android的事件機制是基于回調方法的,在用SAX解析xml文檔時候,在讀取到文檔開始和結束標簽時候就會回調一個事件,在讀取到其他節(jié)點與內容時候也會回調一個事件。在SAX接口中,事件源是org.xml.sax包中的XMLReader,它通過parser()方法來解析XML文檔,并產生事件。事件處理器是org.xml.sax包中ContentHander、DTDHander、ErrorHandler,以及EntityResolver這4個接口。

這四個接口的詳細說明如下:

事件處理器名稱

事件處理器處理的事件

XMLReader注冊方法

ContentHander

XML文檔的開始與結束,

XML文檔標簽的開始與結束,接收字符數(shù)據(jù),跳過實體,接收元素內容中可忽略的空白等。

setContentHandler(ContentHandler h)

DTDHander

處理DTD解析時產生的相應事件

setDTDHandler(DTDHandler h)

ErrorHandler

處理XML文檔時產生的錯誤

setErrorHandler(ErrorHandler h)

EntityResolver

處理外部實體

setEntityResolver(EntityResolver e)

我們用來做內容解析的回調方法一般都定義在ContentHandler接口中。

ContentHandler接口常用的方法:

startDocument()

當遇到文檔的開頭的時候,調用這個方法,可以在其中做一些預處理的工作。

endDocument()

當文檔結束的時候,調用這個方法,可以在其中做一些善后的工作。

startElement(String namespaceURI, String localName,String qName, Attributes atts)

當讀到開始標簽的時候,會調用這個方法。namespaceURI就是命名空間,localName是不帶命名空間前綴的標簽名,qName是帶命名空間前綴的標簽名。通過atts可以得到所有的屬性名和相應的值。

endElement(String uri, String localName, String name)

在遇到結束標簽的時候,調用這個方法。

characters(char[] ch, int start, int length)

這個方法用來處理在XML文件中讀到的內容。例如:high data="30"/主要目的是獲取high標簽中的值。

第一個參數(shù)用于存放文件的內容,后面兩個參數(shù)是讀到的字符串在這個數(shù)組中的起始位置和長度,使用new String(ch,start,length)就可以獲取內容。

注意:

SAX的一個重要特點就是它的流式處理,當遇到一個標簽的時候,它并不會紀錄下之前所碰到的標簽,即在startElement()方法中,所有能夠知道的信息,就是標簽的名字和屬性,至于標簽的嵌套結構,上層標簽的名字,是否有子元屬等等其它與結構相關的信息,都是不知道的,都需要你的程序來完成。這使得SAX在編程處理上沒有DOM方便。

現(xiàn)在我們截取一段XML文件來做解析,其調用方法是這樣的:

?xml version="1.0"? ---------- startDocument()

weather ---------- startElement

forecast_information ---------- startElement

city ---------- startElement

beijing ---------- characters

/city ---------- endElement

/forecast_information ---------- endElement

/weather ---------- endElement

文檔結束 ---------- endDocument()

SAX的解析步驟:

首先需要注意的是:

SAX還為其制定了一個Helper類:DefaultHandler它實現(xiàn)了ContentHandler這個接口,但是其所有的方法體都為空,在實現(xiàn)的時候,你只需要繼承這個類,然后重載相應的方法即可。

使用SAX解析XML文件一般有以下五個步驟:

1、創(chuàng)建一個SAXParserFactory對象;

2、調用SAXParserFactory中的newSAXParser方法創(chuàng)建一個SAXParser對象;

3、然后在調用SAXParser中的getXMLReader方法獲取一個XMLReader對象;

4、實例化一個DefaultHandler對象

5、連接事件源對象XMLReader到事件處理類DefaultHandler中

6、調用XMLReader的parse方法從輸入源中獲取到的xml數(shù)據(jù)

7、通過DefaultHandler返回我們需要的數(shù)據(jù)集合。

我們仍然來解析上述那個天氣預報的XML文件。

編寫代碼如下:

[java] view plaincopy

mySAX.setOnClickListener(new Button.OnClickListener(){

@Override

public void onClick(View v) {

try{

String url = ";weather=beijing";

DefaultHttpClient client = new DefaultHttpClient();

HttpUriRequest req = new HttpGet(url);

HttpResponse resp = client.execute(req);

HttpEntity ent = resp.getEntity();

InputStream stream = ent.getContent(); //將文件導入流,因此用InputStream

SAXParserFactory saxFactory = SAXParserFactory.newInstance(); //獲取一個對象

SAXParser saxParser = saxFactory.newSAXParser();//利用獲取到的對象創(chuàng)建一個解析器

XMLContentHandler handler = new XMLContentHandler();//設置defaultHandler

saxParser.parse(stream, handler);//進行解析

stream.close();//關閉流

/*XMLReader xmlReader = saxFactory.newSAXParser().getXMLReader(); //獲取一個XMLReader

xmlReader.setContentHandler(handler);

xmlReader.parse(new InputSource(stream));

stream.close();*/

}catch(Exception e){

e.printStackTrace();

}

}

});

}

public class XMLContentHandler extends DefaultHandler {

private static final String TAG = "XMLContentHandler";

@Override

public void characters(char[] ch, int start, int length)

throws SAXException {

Log.i(TAG, "解析內容:"+new String(ch,start,length));

}

@Override

public void endDocument() throws SAXException {

super.endDocument();

Log.i(TAG, "文檔解析完畢。");

}

@Override

public void endElement(String uri, String localName, String qName)

throws SAXException {

Log.i(TAG, localName+"解析完畢");

}

@Override

public void startDocument() throws SAXException {

Log.i(TAG, "開始解析... ...");

}

@Override

public void startElement(String uri, String localName, String qName,

Attributes attributes) throws SAXException {

Log.i(TAG, "解析元素:"+localName);

if(localName.equals("high")){

Log.i(TAG, "解析元素:"+localName);

i++;

if(i==2){

highestTmp.setText(String.valueOf((Integer.parseInt(attributes.getValue(0))-32)*5/9));

}

}

}

}

上面的那段注釋:

[java] view plaincopy

/*XMLReader xmlReader =saxFactory.newSAXParser().getXMLReader(); //獲取一個XMLReader

xmlReader.setContentHandler(handler);

xmlReader.parse(newInputSource(stream));

stream.close();*/

是用XMLReader來做解析的另外一種方法。效果是一樣的。這里可以傳流,也可以傳一個字符串,如下所示:是傳字符串。

[java] view plaincopy

xmlReader.parse(new InputSource(new StringReader(xmlStr)));

PULL方式

除了可以使用 SAX和DOM解析XML文件,也可以使用Android內置的Pull解析器解析XML文件。 Pull解析器的運行方式與 SAX 解析器相似。它也是事件觸發(fā)的。Pull解析方式讓應用程序完全控制文檔該怎么樣被解析。比如開始和結束元素事件,使用parser.next()可以進入下一個元素并觸發(fā)相應事件。通過Parser.getEventType()方法來取得事件的代碼值,解析是在開始時就完成了大部分處理。事件將作為數(shù)值代碼被發(fā)送,因此可以使用一個switch對感興趣的事件進行處理。

Pull解析是一個遍歷文檔的過程,每次調用next(),nextTag(), nextToken()和nextText()都會向前推進文檔,并使Parser停留在某些事件上面,但是不能倒退。然后把文檔設置給Parser。

Android中對Pull方法提供了支持的API,主要是

org.xmlpull.v1.XmlPullParser;

org.xmlpull.v1.XmlPullParserFactory;

二個類,其中主要使用的是XmlPullParser,XmlPullParserFactory是一個工廠,用于構建XmlPullParser對象。

應用程序通過調用XmlPullParser.next()等方法來產生Event,然后再處理Event。

我們仍然拿上述天氣預報的XML文件的一部分來做例子。

例如:需要解析的XML文件是:

[java] view plaincopy

forecast_conditions

day_of_week data="周三"/

low data="22"/

high data="29"/

icon data="/ig/images/weather/chance_of_rain.gif"/

condition data="可能有雨"/

/forecast_conditions

這部分XML文件中day_of_week,low,high等是TAG,data是ATTRIBUTEA。當然,如果有/夾在開始和結束符號之間的部分,則為TXET。

要想解析文檔先要構建一個XmlPullParser對象。

[java] view plaincopy

final XmlPullParserFactory factory = XmlPullParserFactory.newInstance();

factory.setNamespaceAware(true);

final XmlPullParser parser = factory.newPullParser();

parser.setInput(new StringReader("xmlStr");

這里的xmlStr就是上邊的XML文件。

此時,文檔剛被初始化,所以它應該位于文檔的開始,事件為START_DOCUMENT,可以通過XmlPullParser.getEventType()來獲取。然后調用next()會產生

START_TAG,這個事件告訴應用程序一個標簽已經開始了,調用getName()會返回" day_of_week ";若有TEXT,則再next()會產生TEXT事件,調用getText()會返回TEXT,由于此處沒有,所以再next(),會產生END_TAG,這個告訴你一個標簽已經處理完了,再next()直到最后處理完TAG,會產生END_DOCUMENT,它告訴你整個文檔已經處理完成了。除了next()外,nextToken()也可以使用,只不過它會返回更加詳細的事件,比如COMMENT, CDSECT, DOCDECL, ENTITY等等非常詳細的信息。如果程序得到比較底層的信息,可以用nextToken()來驅動并處理詳細的事件。需要注意一點的是TEXT事件是有可能返回空白的White Spaces比如換行符或空格等。

nextTag()--會忽略White Spaces,如果可以確定下一個是START_TAG或END_TAG,就可以調用nextTag()直接跳過去。通常它有二個用處:當START_TAG時,如果能確定這個TAG含有子TAG,那么就可以調用nextTag()產生子標簽的START_TAG事件;當END_TAG時,如果確定不是文檔結尾,就可以調用nextTag()產生下一個標簽的START_TAG。在這二種情況下如果用next()會有TEXT事件,但返回的是換行符或空白符。

nextText()--只能在START_TAG時調用。當下一個元素是TEXT時,TEXT的內容會返回;當下一個元素是END_TAG時,也就是說這個標簽的內容為空,那么空字串返回;這個方法返回后,Parser會停在END_TAG上。

小結一下,如果在一個XML文檔中我們只需要前面一部分數(shù)據(jù),但是使用SAX方式或DOM方式會對整個文檔進行解析,盡管XML文檔中后面的大部分數(shù)據(jù)我們其實都不需要解析,因此這樣實際上就浪費了處理資源。使用PULL方式正合適。

當點擊三種方式的任何一個按鈕時,均能夠得到相同的結果

怎么用手機打開安卓應用里后綴是xml的文件

打開.xml文件的時候,選擇"ES文本閱讀器"打開就可以了

.XML文件由于內容過于簡單僅僅是展示數(shù)據(jù)。所以通常作為文本的形式而存在。事實上這也真是XML與其他數(shù)據(jù)表現(xiàn)形式最大的不同之處:他極其簡單。

這是一個看上去有點瑣細的優(yōu)點,但正是這點使XML與眾不同。XML的簡單使其易于在任何應用程序中讀寫數(shù)據(jù)。而我們要打開.xml文件時只需要通過閱讀器打開即可。

第一步:找到這個XML文件

第二步:選擇使用ES文本閱讀器打開

擴展資料:

在xml之前較為流行的文件格式為SGML,隨著時代的發(fā)展,人們對SGML進行了簡化衍生出HTML。HTML簡單,在初期沒有任何定義文檔外觀的相關方法,僅用來在瀏覽器里顯示網頁文件。而后,隨著因特網的發(fā)展,人們?yōu)榱丝刂破湮募邮剑瑪U充了描述如何顯現(xiàn)數(shù)據(jù)的卷標隨即發(fā)展為了XML。

android中XML文件是如何解析成View

簡要概述

關于視圖的解析過程。大概原理就是通過Layout Inf later的inflate方法,將一個xml布局文檔用pull遞歸解析。然后判斷標簽,如果是merge,include等特殊處理。如果是view或者view group,就通過xml的tag找到指定類,反射new出來,然后add到parent。這里值得一提的是,為了抑制反射造成的效率損失,對反射出來的constructor做了一個map靜態(tài)緩存,下次遇到了同名tag就不用反射了另外,xml從文件中預編譯獲取xml parser的過程也很復雜,在AssetManager有大量緩存(比如相同id的layout只獲取一次,緩存xml block)與native方法,都是為了保證效率。

Android中LayoutInflate解析xml布局文件生成View樹的過程

Android XML布局與View之間的轉換

android里的XML文件是用什么寫的?

XML (eXtensible Markup Language)即可擴展標記語言,它與HTML一樣,都是SGML(Standard Generalized Markup Language,標準通用標記語言)。Xml是Internet環(huán)境中跨平臺的,依賴于內容的技術,是當前處理結構化文檔信息的有力工具。擴展標記語言XML是一種簡單的數(shù)據(jù)存儲語言,使用一系列簡單的標記描述數(shù)據(jù),而這些標記可以用方便的方式建立,雖然XML占用的空間比二進制數(shù)據(jù)要占用更多的空間,但XML極其簡單易于掌握和使用。 XML與Access,Oracle和SQL Server等數(shù)據(jù)庫不同,數(shù)據(jù)庫提供了更強有力的數(shù)據(jù)存儲和分析能力,例如:數(shù)據(jù)索引、排序、查找、相關一致性等,XML僅僅是展示數(shù)據(jù)。事實上XML與其他數(shù)據(jù)表現(xiàn)形式最大的不同是:他極其簡單。這是一個看上去有點瑣細的優(yōu)點,但正是這點使XML與眾不同。 XML與HTML的設計區(qū)別是:XML是用來存儲數(shù)據(jù)的,重在數(shù)據(jù)本身。而HTML是用來定義數(shù)據(jù)的,重在數(shù)據(jù)的顯示模式。 XML的簡單使其易于在任何應用程序中讀寫數(shù)據(jù),這使XML很快成為數(shù)據(jù)交換的唯一公共語言,雖然不同的應用軟件也支持其它的數(shù)據(jù)交換格式,但不久之后他們都將支持XML,那就意味著程序可以更容易的與Windows、Mac OS, Linux以及其他平臺下產生的信息結合,然后可以很容易加載XML數(shù)據(jù)到程序中并分析他,并以XML格式輸出結果。


網站題目:androidxml文件,Androidxml
網址分享:http://weahome.cn/article/dsdioch.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部