Android App中使用Pull解析XML格式數(shù)據(jù)的使用示例
Pull解析XML文件的方式與SAX解析XML文件的方式大致相同,他們都是基于事件驅(qū)動(dòng)的。所以,利用pull解析XML文件需要下面幾個(gè)步驟:
1)通過XMLPullParserFactory獲取XMLPullParser對象。
2)通過XMLPullParser對象設(shè)置輸入流。
3)通過parser.next(),持續(xù)的解析XML文件直到文件的尾部。
下面的幾個(gè)方法是經(jīng)常需要的:XMLPullParserFacotry.newInstance( ) facotry.newPullParser( ) parser.setInput( ) parser.next( ).
下面通過一個(gè)例子描述上面的幾個(gè)步驟:
//1.第一步,創(chuàng)建解析工廠
XmlPullParserFactory factory = XmlPullParserFactory.newInstance();
//設(shè)置支持命名空間
factory.setNamespaceAware(true);
//2.生成parser對象
XmlPullParser parser = factory.newPullParser();
//3.設(shè)置輸入
parser.setInput(new StringReader("<?xml version=\"1.0\" ?><poem><title>靜夜思</title><author>李白</author><content>床前明月光,疑似地上霜,舉頭忘明月,低頭思故鄉(xiāng)</content></poem>"));
//獲取輸入類型
int eventType = parser.getEventType();
while (eventType != XmlPullParser.END_DOCUMENT)
{
if (eventType == XmlPullParser.START_DOCUMENT) {
Log.d("tag", "----"+parser.getName());
}
if (eventType == XmlPullParser.START_TAG) {
Log.d("tag", "----"+parser.getName());
}
if (eventType == XmlPullParser.TEXT) {
Log.d("tag", "----"+parser.getText());
}
if (eventType == XmlPullParser.END_TAG) {
Log.d("tag", "----"+parser.getName());
}
//不斷的去更新
eventType = parser.next();
}
打印出的對象:

pull在android 集成了這種解析,性能和sax差不多,個(gè)人認(rèn)為用來來比sax解析容易多了;采用事件驅(qū)動(dòng)進(jìn)行解析。
dom(Document Object Model)文檔對象模型:是W3C組織推薦的解析XML的一種方式;一般只能只能解析比較小的XML文件;因?yàn)閐om解析是把整個(gè)XML放入內(nèi)存,占用內(nèi)存比較大,但對文檔的
增刪改查標(biāo)膠容易操作。
sax(Simple API for XML)不是官方的標(biāo)準(zhǔn),但它是XML社區(qū)事實(shí)上的標(biāo)準(zhǔn),幾乎所有的XML解析器都支持它。sax解析一般適合xml的讀取,sax解析是從上往下讀取,一行一行來讀。
來看一個(gè)完整的實(shí)例:
package com.android.xiong.documentpullxml;
import java.io.IOException;
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.LinkedHashMap;
import org.xmlpull.v1.XmlPullParser;
import org.xmlpull.v1.XmlPullParserException;
import org.xmlpull.v1.XmlPullParserFactory;
import android.app.Activity;
import android.app.ProgressDialog;
import android.content.DialogInterface;
import android.os.AsyncTask;
import android.os.Bundle;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.TextView;
public class MainActivity extends Activity {
TextView showtxt;
Button btshow;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
showtxt = (TextView) findViewById(R.id.showtxt);
btshow = (Button) findViewById(R.id.showxml);
btshow.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
GetBaiduXmlBooks baiduxml=new GetBaiduXmlBooks();
baiduxml.execute("http://bcs.duapp.com/meinvlook/books.xml");
}
});
}
// 異步任務(wù)
class GetBaiduXmlBooks extends
AsyncTask<String, Integer, LinkedHashMap<String, String>> {
ProgressDialog progress;
// 初始化ProgressDialog
@Override
protected void onPreExecute() {
progress = new ProgressDialog(MainActivity.this);
progress.setTitle("提示!");
progress.setMessage("正在解析百度云存儲(chǔ)的XML");
progress.setCanceledOnTouchOutside(false);
progress.setButton(ProgressDialog.BUTTON_NEUTRAL, "取消",
new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
// 取消任務(wù)
GetBaiduXmlBooks.this.cancel(true);
progress.dismiss();
}
});
progress.show();
}
// 進(jìn)行耗時(shí)操作
@Override
protected LinkedHashMap<String, String> doInBackground(String... params) {
String xmurl = params[0];
LinkedHashMap<String, String> map = new LinkedHashMap<String, String>();
URL url;
try {
url = new URL(xmurl);
HttpURLConnection connection = (HttpURLConnection) url
.openConnection();
connection.setConnectTimeout(10000);
connection.setRequestMethod("GET");
InputStream instream = connection.getInputStream();
// 獲取xml解析器
XmlPullParser parser = XmlPullParserFactory.newInstance()
.newPullParser();
parser.setInput(instream, "UTF-8");
int type=parser.getEventType();
//開始解析xml文件
while (type!= XmlPullParser.END_DOCUMENT) {
if (type == XmlPullParser.START_TAG) {
// 獲取開始標(biāo)簽
if (parser.getName().equals("書名")) {
//獲取節(jié)點(diǎn)的值
map.put("書名", parser.nextText());
}
if (parser.getName().equals("價(jià)格")) {
map.put("價(jià)格", parser.nextText());
}
if (parser.getName().equals("作者")) {
map.put("作者", parser.nextText());
}
if (parser.getName().equals("性別")) {
map.put("性別", parser.nextText());
}
if (parser.getName().equals("年齡")) {
map.put("年齡",parser.nextText());
}
}
type=parser.next();
}
} catch (IOException e) {
e.printStackTrace();
} catch (XmlPullParserException e) {
e.printStackTrace();
}
return map;
}
@Override
protected void onPostExecute(LinkedHashMap<String, String> result) {
for (String txt : result.keySet()) {
showtxt.append(txt+":"+result.get(txt)+"\n");
}
progress.dismiss();
}
}
@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;
}
}
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context=".MainActivity" >
<Button
android:id="@+id/showxml"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="@string/btshowxml"/>
<TextView
android:id="@+id/showtxt"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
</LinearLayout>
<!-- 獲取網(wǎng)絡(luò)權(quán)限 -->
<uses-permission android:name="android.permission.INTERNET"/>
- Android基于Pull方式解析xml的方法詳解
- Android解析XML的三種方式SAX、Pull、Dom
- 實(shí)例解析Android中使用Pull解析器解析XML的方法
- Android編程解析XML方法詳解(SAX,DOM與PULL)
- android4.0混淆XmlPullParser報(bào)錯(cuò)原因分析解決
- Android 使用Pull方法解析XML文件的方法
- Android中使用pull解析器操作xml文件的解決辦法
- Android使用Pull解析器解析xml文件的實(shí)現(xiàn)代碼
- Android中使用PULL方式解析XML文件深入介紹
- Android平臺(tái)基于Pull方式對XML文件解析與寫入方法詳解
相關(guān)文章
關(guān)于Android內(nèi)存緩存LruCache的使用及其源碼解析
LruCache作為內(nèi)存緩存,使用強(qiáng)引用方式緩存有限個(gè)數(shù)據(jù),當(dāng)緩存的某個(gè)數(shù)據(jù)被訪問時(shí),它就會(huì)被移動(dòng)到隊(duì)列的頭部,本文詳細(xì)介紹了關(guān)于Android內(nèi)存緩存LruCache的使用及其源碼解析,需要的朋友可以參考下2023-05-05
Android開發(fā)之圖形圖像與動(dòng)畫(三)Animation效果的XML實(shí)現(xiàn)
使用XML來定義Tween Animation動(dòng)畫的XML文件在工程中res/anim目錄,這個(gè)文件必須包含一個(gè)根元素,感興趣的友可以了解一下,希望本文對你有所幫助2013-01-01
Android編程之手機(jī)壁紙WallPaper設(shè)置方法示例
這篇文章主要介紹了Android編程之手機(jī)壁紙WallPaper設(shè)置方法,結(jié)合實(shí)例形式分析了Android手機(jī)壁紙WallPaper的相關(guān)設(shè)置與使用技巧,需要的朋友可以參考下2017-08-08
Android端“被擠下線”功能的單點(diǎn)登錄實(shí)現(xiàn)
本篇文章主要介紹了Android端“被擠下線”功能的單點(diǎn)登錄實(shí)現(xiàn),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-11-11
Android應(yīng)用更新之自動(dòng)檢測版本及自動(dòng)升級(jí)
這篇文章主要為大家詳細(xì)介紹了Android應(yīng)用更新之自動(dòng)檢測版本及自動(dòng)升級(jí),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-09-09
Android實(shí)現(xiàn)橫向滑動(dòng)卡片效果
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)橫向滑動(dòng)卡片效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-12-12

