Android App中使用Pull解析XML格式数据的使用示例

 更新时间:2016年04月15日 15:17:45   作者:summerpxy  
这篇文章主要介绍了Android App中使用Pull解析XML格式数据的使用示例,Pull是Android中自带的XML解析器,Java里也是一样用:D需要的朋友可以参考下

 Pull解析XML文件的方式与SAX解析XML文件的方式大致相同,他们都是基于事件驱动的。所以,利用pull解析XML文件需要下面几个步骤:

     1)通过XMLPullParserFactory获取XMLPullParser对象。

     2)通过XMLPullParser对象设置输入流。

     3)通过parser.next(),持续的解析XML文件直到文件的尾部。

下面的几个方法是经常需要的:XMLPullParserFacotry.newInstance( )    facotry.newPullParser( )   parser.setInput( )       parser.next( ).

下面通过一个例子描述上面的几个步骤:

//1.第一步,创建解析工厂
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>床前明月光,疑似地上霜,举头忘明月,低头思故乡</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放入内存,占用内存比较大,但对文档的
增删改查标胶容易操作。
sax(Simple API for XML)不是官方的标准,但它是XML社区事实上的标准,几乎所有的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("书名")) { 
              //获取节点的值 
              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> 

<!-- 获取网络权限 --> 
<uses-permission android:name="android.permission.INTERNET"/> 

相关文章

  • Android中使用AspectJ详解

    Android中使用AspectJ详解

    本文主要介绍了Android中使用AspectJ的相关知识。具有很好的参考价值。下面跟着小编一起来看下吧
    2017-04-04
  • OkHttp原理分析小结

    OkHttp原理分析小结

    OkHttp 是 Square 公司开源的一款网络框架,封装了一个高性能的 http 请求库,本文对OkHttp原理给大家详细讲解,感兴趣的朋友跟随小编一起看看吧
    2024-01-01
  • Android实现获取SERIAL信息的方法

    Android实现获取SERIAL信息的方法

    这篇文章主要介绍了Android实现获取SERIAL信息的方法,涉及Android操作SERIAL的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-10-10
  • 创建Android库的方法及Android .aar文件用法小结

    创建Android库的方法及Android .aar文件用法小结

    本文给大家介绍了创建Android库的方法及Android中 .aar文件生成方法与用法详解,涉及到创建库模块操作步骤及开发注意事项,需要的朋友参考下吧
    2017-12-12
  • Android SDK命令行工具Monkey参数及使用解析

    Android SDK命令行工具Monkey参数及使用解析

    这篇文章主要介绍了Android SDK命令行工具Monkey参,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值数及使用解析,需要的朋友可以参考下
    2020-10-10
  • Android屏幕及view的截图实例详解

    Android屏幕及view的截图实例详解

    这篇文章主要介绍了Android屏幕及view的截图实例详解的相关资料,需要的朋友可以参考下
    2017-05-05
  • Kotlin伴随对象的初始化方法示例讲解

    Kotlin伴随对象的初始化方法示例讲解

    Kotlin语言的许多特性,包括变量不可变,变量不可为空,等等。这些特性都是为了尽可能地保证程序安全而设计的,但是有些时候这些特性也会在编码时给我们带来不少的麻烦,下面我们来了解伴随对象的初始化
    2022-11-11
  • Android小米推送简单使用方法

    Android小米推送简单使用方法

    这篇文章主要为大家详细介绍了Android小米推送简单使用方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-01-01
  • Android自动提示控件AutoCompleteTextView

    Android自动提示控件AutoCompleteTextView

    这篇文章主要介绍了Android自动提示控件AutoCompleteTextView的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-12-12
  • android生命周期深入分析(一)

    android生命周期深入分析(一)

    Android 程序的生命周期是由系统控制而非程序自身直接控制,本文将详细介绍,需要的朋友可以参考下
    2012-12-12

最新评论