Android解析XML(PULL方式)
PULL 的工作原理:
XML pull提供了开始元素和结束元素。当某个元素开始时,可以调用parser.nextText从XML文档中提取所有字符数据。当解析到一个文档结束时,自动生成EndDocument事件。
常用的XML pull的接口和类:
XmlPullParser:该解析器是一个在org.xmlpull.v1中定义的解析功能的接口。
XmlSerializer:它是一个接口,定义了XML信息集的序列。
XmlPullParserFactory:这个类用于在XMPULL V1 API中创建XML Pull解析器。
XmlPullParserException:抛出单一的XML pull解析器相关的错误。
PULL解析器的运行方式和SAX类似,都是基于事件的模式。
不同的是,在PULL解析过程中返回的是数字,且我们需要自己获取产生的事件然后做相应的操作,而不像SAX那样由处理器触发一种事件的方法,执行我们的代码:
读取到xml的声明返回 START_DOCUMENT; 结束返回 END_DOCUMENT ; 开始标签返回 START_TAG;
结束标签返回 END_TAG; 文本返回 TEXT。
使用:
Book.xml(xml文件)
- <?xml version="1.0" encoding="utf-8"?>
- <books>
- <book>
- <id>1</id>
- <name>Android开发范例大全(第一版)</name>
- <price>69.00</price>
- </book>
- <book>
- <id>2</id>
- <name>Android开发范例大全(第二版)</name>
- <price>79.00</price>
- </book>
- <book>
- <id>3</id>
- <name>Android开发范例大全(第三版)</name>
- <price>89.00</price>
- </book>
- </books>
Book.java(实体类)
- public class Book {
- private int id;
- private String name;
- private float price;
- public int getId() {
- return id;
- }
- public void setId(int id) {
- this.id = id;
- }
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- public float getPrice() {
- return price;
- }
- public void setPrice(float price) {
- this.price = price;
- }
- }
PullXmlActivity.java(Activity)
- public class PullXmlActivity extends Activity{
- private List<Book> list=null;
- private PullXmlAdapter adapter;
- private ListView lv;
- @Override
- protected void onCreate(Bundle savedInstanceState) {
- // TODO Auto-generated method stub
- super.onCreate(savedInstanceState);
- setContentView(R.layout.listview);
- lv=(ListView)findViewById(R.id.listView);
- InputStream in;
- try {
- in = this.getAssets().open("books.xml");
- list=pullxml(in);
- } catch (IOException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- } catch (Exception e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }
- adapter=new PullXmlAdapter(PullXmlActivity.this, list);
- lv.setAdapter(adapter);
- }
- /**xml文件的获取
- * 1.xml文件放在res的xml文件夹下(推荐)使用XmlResourceParser xmlParser = this.getResources().getXml(R.xml.XXX);
- * 2.xml文件放在raw的xml文件夹下使用InputStream inputStream =this.getResources().openRawResource(R.raw.XXX);
- * 3.xml文件放在assets文件夹下(本人测试发现通过此方法获取的XML文档不能带有首行:<?xml version="1.0" encoding="utf-8"?>,
- * 否则解析报错,具体原因未查明:InputStream inputStream = getResources().getAssets().open(fileName);
- * 4.xml文件放在SD卡, path路径根据实际项目修改,此次获取SDcard根目录:
- * String path = Environment.getExternalStorageDirectory().toString();
- * File xmlFlie = new File(path+fileName);
- * InputStream inputStream = new FileInputStream(xmlFlie);
- */
- public List<Book> pullxml(InputStream in)throws Exception{
- List<Book> list=null;
- Book book = null;
- // 由android.util.Xml创建一个XmlPullParser实例
- XmlPullParser parser = Xml.newPullParser();
- // 设置输入流 并指明编码方式
- parser.setInput(in, "UTF-8");
- // 产生第一个事件
- int eventType = parser.getEventType();
- while (eventType != XmlPullParser.END_DOCUMENT) {
- switch (eventType) {
- // 判断当前事件是否为文档开始事件
- case XmlPullParser.START_DOCUMENT:
- list=new ArrayList<Book>();// 初始化list集合
- break;
- // 判断当前事件是否为标签元素开始事件
- case XmlPullParser.START_TAG:
- if (parser.getName().equals("book")) { // 判断开始标签元素是否是book
- book = new Book();
- } else if (parser.getName().equals("id")) {
- eventType = parser.next();
- // 得到book标签的属性值,并设置book的id
- book.setId(Integer.parseInt(parser.getText()));
- } else if (parser.getName().equals("name")) { // 判断开始标签元素是否是book
- eventType = parser.next();
- book.setName(parser.getText());
- } else if (parser.getName().equals("price")) { // 判断开始标签元素是否是price
- eventType = parser.next();
- book.setPrice(Float.parseFloat(parser.getText()));
- }
- break;
- // 判断当前事件是否为标签元素结束事件
- case XmlPullParser.END_TAG:
- if (parser.getName().equals("book")) { // 判断结束标签元素是否是book
- list.add(book); // 将book添加到books集合
- book = null;
- }
- break;
- }
- // 进入下一个元素并触发相应事件
- eventType = parser.next();
- }
- return list;
- }
- }
PullXmlAdapter.java (适配器)
- public class PullXmlAdapter extends BaseAdapter {
- private List<Book> list=null;
- private Context context=null;
- private LayoutInflater inflater=null;
- public PullXmlAdapter(Context context,List<Book> list) {
- // TODO Auto-generated constructor stub
- this.context=context;
- this.list=list;
- }
- @Override
- public int getCount() {
- // TODO Auto-generated method stub
- return list.size();
- }
- @Override
- public Object getItem(int arg0) {
- // TODO Auto-generated method stub
- return arg0;
- }
- @Override
- public long getItemId(int arg0) {
- // TODO Auto-generated method stub
- return arg0;
- }
- @Override
- public View getView(int arg0, View arg1, ViewGroup arg2) {
- // TODO Auto-generated method stub
- inflater=LayoutInflater.from(context);
- View v=inflater.inflate(R.layout.listview_item, null);
- TextView tv=(TextView)v.findViewById(R.id.lisview_item_tv);
- tv.setText(list.get(arg0).getName());
- return v;
- }
- }
最后显示结果:
Android解析XML(PULL方式)的更多相关文章
- Android 解析XML—pull解析方式
在Android中,常见的XML解析器分别为SAX解析器.DOM解析器和PULL解析器,其中PULL解析器小巧轻便,解析速度快,简单易用,非常适合在Android移动设备中使用,Android系统内部 ...
- android解析xml (pull)
1. xml <persons> <person id="18"> <name>furong</name> <age>2 ...
- android解析XML总结(SAX、Pull、Dom三种方式) <转载>
android解析XML总结(SAX.Pull.Dom三种方式) http://www.cnblogs.com/JerryWang1991/archive/2012/02/24/2365507.htm ...
- android解析xml文件的方式
android解析xml文件的方式 作者:东子哥 ,发布于2012-11-26,来源:博客园 在androd手机中处理xml数据时很常见的事情,通常在不同平台传输数据的时候,我们就可能使用xm ...
- (转)Android 创建与解析XML—— Dom4j方式 .
转:http://blog.csdn.net/ithomer/article/details/7521605 1.Dom4j概述 dom4j is an easy to use, open sourc ...
- Android中三种常用解析XML的方式(DOM、SAX、PULL)简介及区别
XML在各种开发中都广泛应用,Android也不例外.作为承载数据的一个重要角色,如何读写XML成为Android开发中一项重要的技能.今天就由我向大家介绍一下在Android平台下几种常见的XML解 ...
- android 解析XML方式(三)
上一节中,我们使用SAX方式解析xml文档, SAX方式是基于事件驱动的.当然android的事件机制是基于回调函数的.在这一节中,我们用另外一种方式解析xml文档,这种方式也是基于事件驱动的,与SA ...
- android 解析XML方式(一)
在androd手机中处理xml数据时很常见的事情,通常在不同平台传输数据的时候,我们就可能使用xml,xml是与平台无关的特性,被广泛运用于数据通信中,那么在android中如何解析xml文件数据呢? ...
- Android解析xml文件-采用DOM,PULL,SAX三种方法解析
解析如下xml文件 <?xml version="1.0" encoding="UTF-8"?> <persons> <perso ...
随机推荐
- [codeforces 325]B. Stadium and Games
[codeforces 325]B. Stadium and Games 试题描述 Daniel is organizing a football tournament. He has come up ...
- 重写HashMap
package gov.gfmis.fap.util; import java.util.ArrayList; import java.util.HashMap; import java.util.L ...
- C#结构体和类的区别
1.不能在结构体中定义默认构造方法: 2.在结构体中的非默认构造方法中,必须对结构体中所有的字段进行初始化,否则将报错. 3.在类中声明字段的同时,可以初始化,字段的值.在结构体中不可以. 4.结构体 ...
- mysql数据库性能优化(包括SQL,表结构,索引,缓存)
优化目标减少 IO 次数IO永远是数据库最容易瓶颈的地方,这是由数据库的职责所决定的,大部分数据库操作中超过90%的时间都是 IO 操作所占用的,减少 IO 次数是 SQL 优化中需要第一优先考虑,当 ...
- MySQL 如何只导出 指定的表 的表结构和数据 ( 转 )
MySQL 如何只导出 指定的表 的表结构和数据 ( 转 ) 2011-01-04 15:03:33 分类: MySQL MySQL 如何只导出 指定的表 的表结构和数据 导出更个库的表结构如下:my ...
- Find Leaves of Binary Tree
Given a binary tree, collect a tree's nodes as if you were doing this: Collect and remove all leaves ...
- Expected MultipartHttpServletRequest: is a MultipartResolver configured?
2015-05-05 19:09:47.510::WARN: /purchase/long-term-contract/uploading.htmjava.lang.IllegalArgumentEx ...
- 46. 对称子字符串的最大长度(ToDo)
[题目] 输入一个字符串,输出该字符串中对称的子字符串的最大长度.比如输入字符串“google”,由于该字符串里最长的对称子字符串是“goog”,因此输出4. [分析] 可能很多人都写过判断一个字符串 ...
- 1.django笔记之django基础
一.django简介 Django是一个开放源代码的Web应用框架,由Python写成.采用了MVC的软件设计模式,即模型M,视图V和控制器C.它最初是被开发来用于管理劳伦斯出版集团旗下的一些以新闻内 ...
- DP:Sumsets(POJ 2229)
数的集合问题 题目大意:给定你一个整数m,你只能用2的k次幂来组合这个数,问你有多少种组合方式? 这一题一看,天啦太简单了,完全背包?是不是? 不过的确这一题可以用完全背包来想,但是交题绝对是TLE ...