當前位置:首頁 » 安卓系統 » android讀寫xml文件

android讀寫xml文件

發布時間: 2024-07-06 18:16:51

❶ Android灝哖PT鏍煎紡鐨刋ML鏁版嵁瑙f瀽錛屽苟瀹炵幇婕旂ず

涓銆俿imple-xml絎涓夋柟jar鍖呰В鏋恱ml鏍煎紡鏁版嵁
simple-xml鏄涓涓獂ml鍜屽硅薄浜掕漿鎿嶄綔宸ュ叿鍖咃紝瀹樻柟緗戝潃涓猴細http://simple.sourceforge.net/錛宩ar鍖呭彲浠ュ埌瀹樼綉涓婁笅杞斤紝絎旇呬嬌鐢ㄧ殑鏄鐩鍓嶆渶鏂扮増鏈鐨刯ar鍖咃紝鍚嶄負simple-xml-2.7.1.jar錛涘簾璇濅笉澶氳翠簡錛屼唬鐮佹墠鏄鏈鐪熷疄闈犺氨鐨勫姏璇併
涓嬮潰鏄鏁翠釜Demo宸ョ▼鏂囦歡鎴鍥撅紝濡備笅鍥撅細

璇Demo涓昏佹槸閫氳繃simple-xml瑙f瀽assets鐩褰曚腑鐨刣ata.xml鏂囦歡鍐呭規暟鎹錛岀劧鍚庢樉紺哄嚭鏉ワ紱
1.data.xml鏂囦歡鍐呭瑰備笅錛

[html] view plain
<?xml version="1.0" encoding="utf-8"?>
<resources>
<?xml version="1.0" encoding="utf-8"?>
<dataContent>
<group>
<groupID>1</groupID>
<groupName>絎涓緇</groupName>
<member>
<name>寮犱笁</name>
<age>22</age>
</member>
<member>
<name>鏉庡洓</name>
<age>24</age>
</member>
<member>
<name>嬈ч槼闆</name>
<age>18</age>
</member>
</group>
<group>
<groupID>2</groupID>
<groupName>絎浜岀粍</groupName>
<member>
<name>鍙稿緬闈</name>
<age>19</age>
</member>
<member>
<name>鍙剁瑱</name>
<age>26</age>
</member>
<member>
<name>鏉ㄩ</name>
<age>25</age>
</member>
</group>
<group>
<groupID>3</groupID>
<groupName>絎涓夌粍</groupName>
<member>
<name>鐜嬮緳</name>
<age>32</age>
</member>
<member>
<name>瑗塊棬鑳滅敺</name>
<age>21</age>
</member>
<member>
<name>寮犻摤</name>
<age>45</age>
</member>
</group>
</dataContent>

</resources>
閫氳繃涓婇潰鐨勬枃浠跺唴瀹癸紝鎴戜滑鐭ラ亾錛岃繖涓鏂囦歡鍐呭逛富瑕佹湁涓夌粍鏁版嵁錛屾瘡緇勬暟鎹鏈変釜涓変釜鎴愬憳緇勶紝姣忎釜鎴愬憳緇勯兘鏈夊悕瀛楀拰騫撮緞榪欎袱涓瀛愬厓緔犮侱emo涓灝嗚繖浜涜В鏋愬嚭鏉ュ唴瀹歸氳繃ExpandableListView鏄劇ず鍑烘潵銆

2.涓婚〉闈MainActivity浠g爜濡備笅錛

[java] view plain
package com.steven.android.simple.xml.activity;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import org.simpleframework.xml.core.Persister;
import android.app.Activity;
import android.os.Bundle;
import android.text.TextUtils;
import android.util.Log;
import android.view.Menu;
import android.widget.ExpandableListView;
import com.steven.android.simple.xml.adapter.ExpandAdapter;
import com.steven.android.simple.xml.parse.DataParseResponse;
/**
* 鎻忚堪錛氫富欏甸潰
* @author stevenhu223
*
*/
public class MainActivity extends Activity {

private final String TAG = "MainActivity";
private ExpandableListView mExpandableListView;
private ExpandAdapter mAdapter;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mExpandableListView = (ExpandableListView) findViewById(R.id.expanlist_content);
try {
matchAndParseData();
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}

/**
* 鍖歸厤鑾峰彇鍜岃В鏋恱ml鏂囦歡鍐呭
* @throws Exception
*/
private void matchAndParseData() throws Exception {
InputStream inputStream = getResources().getAssets().open("data.xml");
String dataContent = convertStreamToString(inputStream);
String content = "";
//姝e垯琛ㄨ揪寮忓尮閰
Pattern DATA_PATTERN= Pattern.compile("[\\S\\s]*(<dataContent>[\\s\\S]*</dataContent>)[\\s\\S]*");
Matcher matcher = DATA_PATTERN.matcher(dataContent);
if (matcher.matches()) {
//鑾峰彇鍖呭惈dataContent鍏冪礌鐨勫唴瀹
content = matcher.group(1);
}
if (!TextUtils.isEmpty(content)) {
DataParseResponse dataResponse = parseToBean(DataParseResponse.class, content);
mAdapter = new ExpandAdapter(this, dataResponse.mGroupEntities);
mExpandableListView.setAdapter(mAdapter);
}
}

/**
* 灝唜ml鏂囦歡鍐呭硅В鏋愭垚瀹炰綋綾

❷ 怎麼打開android項目里的 main.xml文件

從源文件!打開方式用記事本!或者導入到開發工具裡面雙擊就打開了。

main.xml在源代碼源碼如下:

public void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
//R.layout.main,就是在R.java中的R類定義的layout中main,格式為:R.layout.<layout的xml文件名字>,就是對應的res/layout/main.xml文件。
setContentView(R.layout.main);
TextView myTextView = (TextView) findViewById(R.id.myTextView);
myTextView.setText("我的Activity");
Button myButton = (Button) findViewById(R.id.myButton);
myButton.setText("我的按鈕");
}

❸ 在android中怎麼使用pullparse解析.xml文件

Pull解析器的運行方式與 SAX 解析器相似。它提供了類似的事件,如:開始元素和結束元素事件,使用parser.next()可以進入下一個元素並觸發相應事件。跟SAX不同的是, Pull解析器產生的事件是一個數字,而非方法,因此可以使用一個switch對感興趣的事件進行處理。當元素開始解析時,調用parser.nextText()方法可以獲取下一個Text類型節點的值。
下面我們通過Demo例子來介紹如何使用PULL機制來解析XML文件。先看下如下工程的目錄結構:

按以下步驟進行操作:
[1] 新建一個XML文件,命名為student.xml。同時把XML文件放置到assets目錄下。student.xml文件的內容如下:
[html] view plain
<?xml version="1.0" encoding="utf-8"?>
<students>
<student id="20110806100">
<name>小明</name>
<age>22</age>
<sex>男</sex>
</student>
<student id="20110806101">
<name>小李</name>
<age>24</age>
<sex>男</sex>
</student>
<student id="20110806102">
<name>小麗</name>
<age>21</age>
<sex>女</sex>
</student>
</students>

[2] 根據XML文件中的節點目錄,創建一個相對應的實體類,來保存解析的相應信息。在包:com.andyidea.entity下新建Student.java類。
[html] view plain
package com.andyidea.entity;

public class Student {

private String id;
private String name;
private int age;
private String sex;

public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}

}

[3] 定義一個使用PULL解析XML文件的工具類:ParserByPULL.java。
[html] view plain
package com.andyidea.util;

import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;

import org.xmlpull.v1.XmlPullParser;
import org.xmlpull.v1.XmlPullParserFactory;

import android.util.Xml;

import com.andyidea.entity.Student;

public class ParserByPULL {

//採用XmlPullParser來解析XML文件
public static List<Student> getStudents(InputStream inStream) throws Throwable
{
List<Student> students = null;
Student mStudent = null;

//========創建XmlPullParser,有兩種方式=======
//方式一:使用工廠類XmlPullParserFactory
XmlPullParserFactory pullFactory = XmlPullParserFactory.newInstance();
XmlPullParser parser = pullFactory.newPullParser();
//方式二:使用Android提供的實用工具類android.util.Xml
//XmlPullParser parser = Xml.newPullParser();

//解析文件輸入流
parser.setInput(inStream, "UTF-8");
//產生第一個事件
int eventType = parser.getEventType();
//只要不是文檔結束事件,就一直循環
while(eventType!=XmlPullParser.END_DOCUMENT)
{
switch (eventType)
{
//觸發開始文檔事件
case XmlPullParser.START_DOCUMENT:
students = new ArrayList<Student>();
break;
//觸發開始元素事件
case XmlPullParser.START_TAG:
//獲取解析器當前指向的元素的名稱
String name = parser.getName();
if("student".equals(name))
{
//通過解析器獲取id的元素值,並設置student的id
mStudent = new Student();
mStudent.setId(parser.getAttributeValue(0));
}
if(mStudent!=null)
{
if("name".equals(name))
{
//獲取解析器當前指向元素的下一個文本節點的值
mStudent.setName(parser.nextText());
}
if("age".equals(name))
{
//獲取解析器當前指向元素的下一個文本節點的值
mStudent.setAge(new Short(parser.nextText()));
}
if("sex".equals(name))
{
//獲取解析器當前指向元素的下一個文本節點的值
mStudent.setSex(parser.nextText());
}
}
break;
//觸發結束元素事件
case XmlPullParser.END_TAG:
//
if("student".equals(parser.getName()))
{
students.add(mStudent);
mStudent = null;
}
break;
default:
break;
}
eventType = parser.next();
}
return students;
}

❹ Android緋葷粺涓鐨勬暟鎹瀛樺偍鏈夊摢浜涙柟寮


Android緋葷粺涓鐨勬暟鎹瀛樺偍鏈夊摢浜涙柟寮忥紵
Android鏄鐩鍓嶅叏鐞冧嬌鐢ㄦ渶騫挎硾鐨勭Щ鍔ㄦ搷浣滅郴緇熶箣涓錛屽叾寮哄ぇ鐨勬暟鎹瀛樺偍鏈哄埗浣垮緱寮鍙戣呭彲浠ヨ交鏉懼湴灝嗙敤鎴鋒暟鎹淇濆瓨鍦ㄨ懼囦腑錛屼互渚垮簲鐢ㄧ▼搴忛殢鏃跺彲浠ヨ誨彇鍜屽啓鍏ャ傞偅涔堝湪Android涓錛屾暟鎹瀛樺偍鍙堟湁鍝浜涙柟寮忓憿錛
1.SharedPreferences
SharedPreferences鏄疉ndroid涓鐢ㄤ簬淇濆瓨杞婚噺綰ч敭鍊煎規暟鎹鐨勫伐鍏鳳紝鍙浠ョ敤浜庝繚瀛樼敤鎴風殑棣栭夐」璁劇疆銆佺櫥褰曚俊鎮銆佸簲鐢ㄧ▼搴忛厤緗絳夐渶奼傘傚畠鍩轟簬XML鏂囦歡瀹炵幇錛屽彲浠ュ疄鐜板揩閫熺殑璇誨啓鎿嶄綔錛岄傚悎瀛樺偍涓浜涚畝鍗曠殑鏁版嵁銆
2.SQLite鏁版嵁搴
SQLite鏄涓縐嶈交鍨嬫暟鎹搴擄紝甯哥敤浜庡湪縐誨姩璁懼囦腑瀛樺偍緇撴瀯鍖栨暟鎹錛屽寘鎷鐢ㄦ埛璐︽埛淇℃伅銆佽仈緋諱漢銆佹秷鎮璁板綍銆佹棩鍘嗙瓑銆係QLite鏁版嵁搴撳唴緗浜嶢ndroid緋葷粺涓錛屾彁渚涗簡澶ч噺鐨凙PI鎺ュ彛錛屼嬌寰楀紑鍙戜漢鍛樺彲浠ヨ交鏉懼湴榪涜屾暟鎹鐨勫瓨鍌ㄥ拰璁塊棶銆
3.鏂囦歡瀛樺偍
Android鎻愪緵浜嗕竴縐嶅熀浜庢枃浠剁殑鏁版嵁瀛樺偍鏂規硶錛屽彲浠ュ皢鏁版嵁淇濆瓨鍦ㄨ懼囩殑鍐呯疆瀛樺偍鍣ㄦ垨澶栭儴瀛樺偍鍣ㄤ笂錛屼互鏂囦歡褰㈠紡榪涜屽瓨鍌ㄣ傛ょ嶆柟寮忛傜敤浜庡瓨鍌ㄤ竴浜涢潪緇撴瀯鍖栨暟鎹錛屼緥濡傚浘鐗囥侀煶棰戙佽嗛戠瓑銆
4.ContentProvider
ContentProvider鏄涓縐嶅疄鐜癆ndroid鏁版嵁鍏變韓鐨勬満鍒訛紝鍏佽鎬笉鍚屽簲鐢ㄧ▼搴忎箣闂村叡浜鏁版嵁銆備篃鍙浠ュ湪澶氫釜緇勪歡涔嬮棿鍏變韓鏁版嵁錛屼緥濡傚湪Activity鍜孲ervice涔嬮棿鍏變韓鏁版嵁銆侰ontentProvider閫氬父鐢ㄤ簬瀛樺偍闈炲父閲嶈佺殑鏁版嵁錛屼緥濡傝仈緋諱漢淇℃伅銆佹棩鍘嗕簨浠躲佸獟浣撴枃浠剁瓑銆
5.RoomPersistenceLibrary
RoomPersistenceLibrary鏄疓oogle鍦ˋndroid騫沖彴涓婁負寮鍙戜漢鍛樻彁渚涚殑涓縐嶈交閲忕駭銆佺畝媧佺殑ORM妗嗘灦錛岀敤浜庣$悊SQLite鏁版嵁搴撲腑鐨勭粨鏋勫寲鏁版嵁銆俁oom搴撶畝鍖栦簡Android搴旂敤紼嬪簭涓鏁版嵁鐨勫勭悊錛屼粠鑰屼嬌寰楀紑鍙戜漢鍛樺彲浠ヨ交鏉懼湴榪涜屽畨鍏ㄣ佷竴鑷村拰楂樻晥鐨勬暟鎹瀛樺偍鎿嶄綔銆
緇間笂鎵榪幫紝Android鎻愪緵浜嗗氱嶆暟鎹瀛樺偍鏂瑰紡錛屽紑鍙戜漢鍛樺彲浠ユ牴鎹闇奼傝繘琛岄夋嫨錛屼緥濡係haredPreferences閫傜敤浜庡瓨鍌ㄨ交閲忕駭鐨勬暟鎹錛孲QLite鏁版嵁搴撻傜敤浜庡瓨鍌ㄧ粨鏋勫寲鏁版嵁錛屾枃浠跺瓨鍌ㄩ傜敤浜庡瓨鍌ㄥぇ鍨嬪獟浣撴枃浠訛紝ContentProvider閫傜敤浜庡疄鐜板叡浜鏁版嵁錛岃孯oomPersistenceLibrary鍒欐槸涓縐嶇畝渚跨殑ORM妗嗘灦錛岄傜敤浜庣$悊SQLite鏁版嵁搴撲腑鐨勭粨鏋勫寲鏁版嵁銆傞夋嫨鍚堥傜殑鏁版嵁瀛樺偍鏂瑰紡鍙浠ユ洿濂藉湴綆$悊鍜岀淮鎶Android搴旂敤紼嬪簭涓鐨勬暟鎹銆

❺ android中怎麼解析復雜的xml文件

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

文件內容如下所示:
那麼就是要對此XML文件做解析。下面我們就分別用DOM,SAX和PULL三種方式,分別對此XML文件做解析。

DOM方式

DOM方式解析xml是先把xml文檔都讀到內存中,然後再用DOM API來訪問樹形結構,並獲取數據。由DOM解析的方式可以知道,如果XML文件很大的時候,處理效率就會變得比較低,這也是DOM方式的一個缺點。
現在我們來解析上文中提到的有關天氣預報信息相關的xml文件。什麼是解析呢?說的通俗一點,就是將這個帶標簽的XML文件識別出來,並抽取一些相關的,對我們有用的信息來給我們使用。那在這個文件里,時間,天氣,溫度,以及圖標對我們來說是需要得到的。我們要對其做解析。
解析的具體思路是:
1. 將XML文件載入進來。
2. 獲取文檔的根節點
3. 獲取文檔根節點中所有子節點的列表
4. 獲取子節點列表中需要讀取的節點信息
根據這4個步驟,我們進行開發:
首先就是如何載入XML文件,假設此文件來源於網路。

SAX方式

SAX是Simple API for XML的縮寫。是一個包也可以看成是一些介面。
相比於DOM而言SAX是一種速度更快,更有效,佔用內存更少的解析XML文件的方法。它是逐行掃描,可以做到邊掃描邊解析,因此SAX可以在解析文檔的任意時刻停止解析。非常適用於Android等移動設備。
SAX是基於事件驅動的。所謂事件驅動就是說,它不用解析完整個文檔,在按內容順序解析文檔過程中,SAX會判斷當前讀到的字元是否符合XML文件語法中的某部分。如果符合某部分,則會觸發事件。所謂觸發事件,就是調用一些回調方法。當然android的事件機制是基於回調方法的,在用SAX解析xml文檔時候,在讀取到文檔開始和結束標簽時候就會回調一個事件,在讀取到其他節點與內容時候也會回調一個事件。在SAX介面中,事件源是org.xml.sax包中的XMLReader,它通過parser()方法來解析XML文檔,並產生事件。事件處理器是org.xml.sax包中ContentHander、DTDHander、ErrorHandler,以及EntityResolver這4個介面。
這四個介面的詳細說明如下:

事件處理器名稱

事件處理器處理的事件

XMLReader注冊方法

ContentHander

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

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標簽中的值。
第一個參數用於存放文件的內容,後面兩個參數是讀到的字元串在這個數組中的起始位置和長度,使用new String(ch,start,length)就可以獲取內容。
注意:
SAX的一個重要特點就是它的流式處理,當遇到一個標簽的時候,它並不會紀錄下之前所碰到的標簽,即在startElement()方法中,所有能夠知道的信息,就是標簽的名字和屬性,至於標簽的嵌套結構,上層標簽的名字,是否有子元屬等等其它與結構相關的信息,都是不知道的,都需要你的程序來完成。這使得SAX在編程處理上沒有DOM方便。
現在我們截取一段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它實現了ContentHandler這個介面,但是其所有的方法體都為空,在實現的時候,你只需要繼承這個類,然後重載相應的方法即可。
使用SAX解析XML文件一般有以下五個步驟:
1、創建一個SAXParserFactory對象;
2、調用SAXParserFactory中的newSAXParser方法創建一個SAXParser對象;
3、然後在調用SAXParser中的getXMLReader方法獲取一個XMLReader對象;
4、實例化一個DefaultHandler對象
5、連接事件源對象XMLReader到事件處理類DefaultHandler中
6、調用XMLReader的parse方法從輸入源中獲取到的xml數據
7、通過DefaultHandler返回我們需要的數據集合。
我們仍然來解析上述那個天氣預報的XML文件。
編寫代碼如下:

[java] view plain
mySAX.setOnClickListener(new Button.OnClickListener(){
@Override
public void onClick(View v) {
try{
String url = "http://www.google.com/ig/api?&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();//利用獲取到的對象創建一個解析器
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 plain
/*XMLReader xmlReader =saxFactory.newSAXParser().getXMLReader(); //獲取一個XMLReader
xmlReader.setContentHandler(handler);
xmlReader.parse(newInputSource(stream));
stream.close();*/

是用XMLReader來做解析的另外一種方法。效果是一樣的。這里可以傳流,也可以傳一個字元串,如下所示:是傳字元串。
[java] view plain
xmlReader.parse(new InputSource(new StringReader(xmlStr)));
PULL方式
除了可以使用 SAX和DOM解析XML文件,也可以使用Android內置的Pull解析器解析XML文件。 Pull解析器的運行方式與 SAX 解析器相似。它也是事件觸發的。Pull解析方式讓應用程序完全控制文檔該怎麼樣被解析。比如開始和結束元素事件,使用parser.next()可以進入下一個元素並觸發相應事件。通過Parser.getEventType()方法來取得事件的代碼值,解析是在開始時就完成了大部分處理。事件將作為數值代碼被發送,因此可以使用一個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 plain
<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 plain
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文檔中我們只需要前面一部分數據,但是使用SAX方式或DOM方式會對整個文檔進行解析,盡管XML文檔中後面的大部分數據我們其實都不需要解析,因此這樣實際上就浪費了處理資源。使用PULL方式正合適。
當點擊三種方式的任何一個按鈕時,均能夠得到相同的結果

❻ android中用xmlpullparser解析xml文件,以及res/raw和assets的不同

XML:可擴展標記語言
讀XML,XML文件的解析

三種解析XML的文件的方式
1.SAX事件驅動不是一次性載入到內存
2.DOM一次載入到內存,性能較差適合伺服器端編程
3.XMLPULL適應嵌入式設備,佔用內存較小API相對簡單

OpenAPI

JSON:相對於XML格式,更節省空間。
1)大括弧開始結束{}
2)內容部分每條數據以「,」分隔
3)每條數據由鍵值對構成,key必須是字元串「」
4)值可以是:String、double、int、long、boolean、
jsonObject、jsonArray

把要解析的XML文件放在assets目錄下,這里解釋下

res/raw和assets的相同點:
兩者目錄下的文件在打包後會原封不動的保存在apk包中,不會被編譯成二進制。
res/raw和assets的不同點:
1.res/raw中的文件會被映射到R.java文件中,訪問的時候直接使用資源ID即R.id.filename;assets文件夾下的文件不會被映射到R.java中,訪問的時候需要AssetManager類。
2.res/raw不可以有目錄結構,而assets則可以有目錄結構,也就是assets目錄下可以再建立文件夾
讀取文件資源:
1.讀取res/raw下的文件資源,通過以下方式獲取輸入流來進行寫操作
·InputStreamis=getResources().openRawResource(R.id.filename);
2.讀取assets下的文件資源,通過以下方式獲取輸入流來進行寫操作
·AssetManageram=null;
·am=getAssets();
·InputStreamis=am.open("filename");
注意1:Google的Android系統處理Assert有個bug,在AssertManager中不能處理單個超過1MB的文件,不然會報異常,raw沒這個限制可以放個4MB的Mp3文件沒問題。

注意2:assets文件夾是存放不進行編譯加工的原生文件,即該文件夾裡面的文件不會像xml,java文件被預編譯,可以存放一些圖片,html,js,css等文件。
解析如下文件


1

2

3

4

5

6

7

8<TextView

android:id="@+id/textView1"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:layout_alignParentRight="true"

android:layout_alignTop="@+idtton1"

android:text="LargeText"

android:textAppearance="?android:attr/textAppearanceLarge"/>

代碼如下:


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20XmlPullParserpullParser=Xml.newPullParser();//得到XML解析器

AssetManagerassetManager=getAssets();//文件保存在assets目錄下,得到assetManager管理器

InputStreamis;

try

{

is=assetManager.open("activity_main.xml");//打開文件,得到輸入流

pullParser.setInput(is,"utf-8");//StringinputEncoding格式

inteventType=pullParser.getEventType();//得到事件類型

while(eventType!=XmlPullParser.END_DOCUMENT)//文檔的末尾

{//遍歷內部的內容

Stringname=pullParser.getName();

if("TextView".equals(name))

{

Stringvalue=pullParser.getAttributeValue(2);//得到屬性值(位置)

textView.setText("顯示結果為:"+value);

break;/到就返回

}

eventType=pullParser.next();//讀取下一個標簽

}

}


顯示結果為:

熱點內容
穿越火線掛機腳本 發布:2024-10-05 13:05:44 瀏覽:33
分解質因數c語言 發布:2024-10-05 12:15:53 瀏覽:777
mysql存儲過程字元編碼 發布:2024-10-05 12:05:48 瀏覽:182
c語言命名 發布:2024-10-05 11:56:38 瀏覽:617
編程哪個好學習 發布:2024-10-05 11:50:59 瀏覽:999
為什麼不買安卓旗艦 發布:2024-10-05 11:46:04 瀏覽:380
ostcb編譯條件 發布:2024-10-05 11:28:24 瀏覽:993
win10怎麼關閉登錄密碼 發布:2024-10-05 11:09:55 瀏覽:935
降溫解壓器 發布:2024-10-05 10:54:15 瀏覽:421
軋鋼壓縮空氣 發布:2024-10-05 10:54:10 瀏覽:185