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(); }
打印出的对象:
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 App中使用Pull解析XML格式数据的使用示例全部内容,希望文章能够帮你解决Android App中使用Pull解析XML格式数据的使用示例所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)