欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android App中使用Pull解析XML格式數(shù)據(jù)的使用示例

 更新時間:2016年04月15日 15:17:45   作者:summerpxy  
這篇文章主要介紹了Android App中使用Pull解析XML格式數(shù)據(jù)的使用示例,Pull是Android中自帶的XML解析器,Java里也是一樣用:D需要的朋友可以參考下

 Pull解析XML文件的方式與SAX解析XML文件的方式大致相同,他們都是基于事件驅動的。所以,利用pull解析XML文件需要下面幾個步驟:

     1)通過XMLPullParserFactory獲取XMLPullParser對象。

     2)通過XMLPullParser對象設置輸入流。

     3)通過parser.next(),持續(xù)的解析XML文件直到文件的尾部。

下面的幾個方法是經(jīng)常需要的:XMLPullParserFacotry.newInstance( )    facotry.newPullParser( )   parser.setInput( )       parser.next( ).

下面通過一個例子描述上面的幾個步驟:

//1.第一步,創(chuàng)建解析工廠
XmlPullParserFactory factory = XmlPullParserFactory.newInstance();
//設置支持命名空間
factory.setNamespaceAware(true);
//2.生成parser對象     
XmlPullParser parser = factory.newPullParser();
//3.設置輸入
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();
 }

打印出的對象:

2016415151330157.png (640×238)

pull在android 集成了這種解析,性能和sax差不多,個人認為用來來比sax解析容易多了;采用事件驅動進行解析。
dom(Document Object Model)文檔對象模型:是W3C組織推薦的解析XML的一種方式;一般只能只能解析比較小的XML文件;因為dom解析是把整個XML放入內(nèi)存,占用內(nèi)存比較大,但對文檔的
增刪改查標膠容易操作。
sax(Simple API for XML)不是官方的標準,但它是XML社區(qū)事實上的標準,幾乎所有的XML解析器都支持它。sax解析一般適合xml的讀取,sax解析是從上往下讀取,一行一行來讀。

來看一個完整的實例:

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"); 
      } 
    }); 
  } 
 
  // 異步任務 
  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("正在解析百度云存儲的XML"); 
      progress.setCanceledOnTouchOutside(false); 
      progress.setButton(ProgressDialog.BUTTON_NEUTRAL, "取消", 
          new DialogInterface.OnClickListener() { 
 
            @Override 
            public void onClick(DialogInterface dialog, int which) { 
              // 取消任務 
              GetBaiduXmlBooks.this.cancel(true); 
              progress.dismiss(); 
            } 
          }); 
      progress.show(); 
    } 
 
    // 進行耗時操作 
    @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) { 
            // 獲取開始標簽 
            if (parser.getName().equals("書名")) { 
              //獲取節(jié)點的值 
              map.put("書名", 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()); 
            } 
            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)絡權限 --> 
<uses-permission android:name="android.permission.INTERNET"/> 

相關文章

  • 關于Android內(nèi)存緩存LruCache的使用及其源碼解析

    關于Android內(nèi)存緩存LruCache的使用及其源碼解析

    LruCache作為內(nèi)存緩存,使用強引用方式緩存有限個數(shù)據(jù),當緩存的某個數(shù)據(jù)被訪問時,它就會被移動到隊列的頭部,本文詳細介紹了關于Android內(nèi)存緩存LruCache的使用及其源碼解析,需要的朋友可以參考下
    2023-05-05
  • Android開發(fā)之圖形圖像與動畫(三)Animation效果的XML實現(xiàn)

    Android開發(fā)之圖形圖像與動畫(三)Animation效果的XML實現(xiàn)

    使用XML來定義Tween Animation動畫的XML文件在工程中res/anim目錄,這個文件必須包含一個根元素,感興趣的友可以了解一下,希望本文對你有所幫助
    2013-01-01
  • Flutter3.7新增Menu菜單組件的使用教程分享

    Flutter3.7新增Menu菜單組件的使用教程分享

    之前Flutter的菜單選擇、下拉菜單的支持非常簡單且不友好,對于非常常見的下拉菜單選擇功能是需要自己自定義實現(xiàn),今天看到Flutter3.7版本新增了一系列菜單的組件,馬上來試試
    2023-01-01
  • Android編程之手機壁紙WallPaper設置方法示例

    Android編程之手機壁紙WallPaper設置方法示例

    這篇文章主要介紹了Android編程之手機壁紙WallPaper設置方法,結合實例形式分析了Android手機壁紙WallPaper的相關設置與使用技巧,需要的朋友可以參考下
    2017-08-08
  • Android端“被擠下線”功能的單點登錄實現(xiàn)

    Android端“被擠下線”功能的單點登錄實現(xiàn)

    本篇文章主要介紹了Android端“被擠下線”功能的單點登錄實現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11
  • 微信網(wǎng)頁 第三方登錄原理詳解

    微信網(wǎng)頁 第三方登錄原理詳解

    本文主要介紹微信網(wǎng)頁 第三方登錄原理,這里整理了詳細的資料及接口說明和參數(shù)說明,有需要的小伙伴可以參考下
    2016-09-09
  • Android應用更新之自動檢測版本及自動升級

    Android應用更新之自動檢測版本及自動升級

    這篇文章主要為大家詳細介紹了Android應用更新之自動檢測版本及自動升級,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-09-09
  • Android API編程之Assets文件操作示例

    Android API編程之Assets文件操作示例

    這篇文章主要介紹了Android API編程之Assets文件操作,結合實例形式分析了Android針對Assets文件夾下的文件操作相關技巧,需要的朋友可以參考下
    2017-08-08
  • Android實現(xiàn)橫向滑動卡片效果

    Android實現(xiàn)橫向滑動卡片效果

    這篇文章主要為大家詳細介紹了Android實現(xiàn)橫向滑動卡片效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-12-12
  • Android圖片加載庫Glide用法

    Android圖片加載庫Glide用法

    大家好,本篇文章主要講的Android圖片加載庫Glide用法,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12

最新評論