第一种方式(简洁,直接用pullparser.nextText()来返回下一个String类型的值):

 1 package lee.service;
2
3 import java.io.InputStream;
4 import java.util.ArrayList;
5 import java.util.List;
6 import org.xmlpull.v1.XmlPullParser;
7 import android.util.Xml;
8 import lee.vo.Person;
9
10 public class XMLPullService {
11
12 public List<Person> readXML(InputStream inStream) throws Exception{
13
14 List<Person> persons = null;
15
16 Person person = null;
17
18 XmlPullParser pullParser = Xml.newPullParser(); //获取Pull解析器 Xml.newPullParser()添加一个pullParser解析器带命名空间的支持
19
20 pullParser.setInput(inStream, "UTF-8"); //设置Pull解析器进行解析的XML内容
21
22 int event = pullParser.getEventType(); //获取第一个事件
23
24 while(event!=XmlPullParser.END_DOCUMENT) //如果还不是结束文档事件,迭代每一个元素
25 {
26 switch (event)
27 {
28 case XmlPullParser.START_DOCUMENT: //开始文档事件
29 persons = new ArrayList<Person>();
30 break;
31
32 case XmlPullParser.START_TAG: //开始元素事件
33 if("person".equals(pullParser.getName())) //pullParser.getName()得到当前指针所指向的节点的名称
34 {
35 person = new Person();
36 int id = new Integer(pullParser.getAttributeValue(0));
37 person.setId(id);
38 }
39 if(person!=null)
40 {
41 if("name".equals(pullParser.getName()))
42 {
43 String name = pullParser.nextText(); //得到当前节点下一个文本节点的内容------> <name>liming</name> 得到liming
44 person.setName(name);
45 }
46 else if("age".equals(pullParser.getName()))
47 {
48 String age = pullParser.nextText(); //获取下一个Text类型节点的值
49 person.setAge(new Short(age));
50 }
51 }
52 break;
53 case XmlPullParser.END_TAG: //结束元素事件
54 if("person".equals(pullParser.getName()))
55 {
56 persons.add(person);
57 person = null;
58 }
59 break;
60 }
61 event = pullParser.next(); //进入下一个元素并触发相应事件
62 }
63 return persons;
64 }
65 }

第二种方式(较为复杂,用pullparser.Next()来进入下一个元素,用.textNext来返回当前String类型元素的值):

 1 public class PullXmlActivity extends Activity{
2 private List<Book> list=null;
3 private PullXmlAdapter adapter;
4 private ListView lv;
5 @Override
6 protected void onCreate(Bundle savedInstanceState) {
7 // TODO Auto-generated method stub
8 super.onCreate(savedInstanceState);
9 setContentView(R.layout.listview);
10 lv=(ListView)findViewById(R.id.listView);
11 InputStream in;
12 try {
13 in = this.getAssets().open("books.xml");
14
15 list=pullxml(in);
16
17 } catch (IOException e) {
18 // TODO Auto-generated catch block
19 e.printStackTrace();
20 } catch (Exception e) {
21 // TODO Auto-generated catch block
22 e.printStackTrace();
23 }
24 adapter=new PullXmlAdapter(PullXmlActivity.this, list);
25 lv.setAdapter(adapter);
26 }
27 /**xml文件的获取
28 * 1.xml文件放在res的xml文件夹下(推荐)使用XmlResourceParser xmlParser = this.getResources().getXml(R.xml.XXX);
29 * 2.xml文件放在raw的xml文件夹下使用InputStream inputStream =this.getResources().openRawResource(R.raw.XXX);
30 * 3.xml文件放在assets文件夹下(本人测试发现通过此方法获取的XML文档不能带有首行:<?xml version="1.0" encoding="utf-8"?>,
31 * 否则解析报错,具体原因未查明:InputStream inputStream = getResources().getAssets().open(fileName);
32 * 4.xml文件放在SD卡, path路径根据实际项目修改,此次获取SDcard根目录:
33 * String path = Environment.getExternalStorageDirectory().toString();
34 * File xmlFlie = new File(path+fileName);
35 * InputStream inputStream = new FileInputStream(xmlFlie);
36 */
37 public List<Book> pullxml(InputStream in)throws Exception{
38 List<Book> list=null;
39 Book book = null;
40 // 由android.util.Xml创建一个XmlPullParser实例
41 XmlPullParser parser = Xml.newPullParser();
42 // 设置输入流 并指明编码方式
43 parser.setInput(in, "UTF-8");
44 // 产生第一个事件
45 int eventType = parser.getEventType();
46
47 while (eventType != XmlPullParser.END_DOCUMENT) {
48 switch (eventType) {
49 // 判断当前事件是否为文档开始事件
50 case XmlPullParser.START_DOCUMENT:
51 list=new ArrayList<Book>();// 初始化list集合
52 break;
53 // 判断当前事件是否为标签元素开始事件
54 case XmlPullParser.START_TAG:
55 if (parser.getName().equals("book")) { // 判断开始标签元素是否是book
56 book = new Book();
57 } else if (parser.getName().equals("id")) {
58 eventType = parser.next();
59 // 得到book标签的属性值,并设置book的id
60 book.setId(Integer.parseInt(parser.getText()));
61 } else if (parser.getName().equals("name")) { // 判断开始标签元素是否是book
62 eventType = parser.next();
63 book.setName(parser.getText());
64 } else if (parser.getName().equals("price")) { // 判断开始标签元素是否是price
65 eventType = parser.next();
66 book.setPrice(Float.parseFloat(parser.getText()));
67 }
68 break;
69 // 判断当前事件是否为标签元素结束事件
70 case XmlPullParser.END_TAG:
71 if (parser.getName().equals("book")) { // 判断结束标签元素是否是book
72 list.add(book); // 将book添加到books集合
73 book = null;
74 }
75 break;
76 }
77 // 进入下一个元素并触发相应事件
78 eventType = parser.next();
79 }
80 return list;
81 }
82 }

用PULL解析器解析XML文件的更多相关文章

  1. 无废话Android之android下junit测试框架配置、保存文件到手机内存、android下文件访问的权限、保存文件到SD卡、获取SD卡大小、使用SharedPreferences进行数据存储、使用Pull解析器操作XML文件、android下操作sqlite数据库和事务(2)

    1.android下junit测试框架配置 单元测试需要在手机中进行安装测试 (1).在清单文件中manifest节点下配置如下节点 <instrumentation android:name= ...

  2. 使用Pull解析器生成XML文件和读取xml文件

    有些时候,我们需要生成一个XML文件,生成XML文件的方法有很多,如:可以只使用一个StringBuilder组拼XML内容,然后把内容写入到文件中:或者使用DOM API生成XML文件,或者也可以使 ...

  3. 使用Pull解析器生成XML文件

    有些时候,我们需要生成一个XML文件,生成XML文件的方法有很多,如:可以只使用一个StringBuilder组拼XML内容,然后把内容写入到文件中:或者使用DOM API生成XML文件,或者也可以使 ...

  4. Android开发8——利用pull解析器读写XML文件

    一.基本介绍 对XML解析有SAX和DOM等多种方式,Android中极力推荐xmlpull方式解析xml.xmlpull不仅可用在Android上同样也适用于javase,但在javase环境中需自 ...

  5. 使用XML序列化器生成XML文件和利用pull解析XML文件

    首先,指定XML格式,我指定的XML格式如下: <?xml version='1.0' encoding='utf-8' standalone='yes' ?> <message&g ...

  6. JavaScript使用浏览器内置XML解析器解析DOM对象

    所有现代浏览器都内建了供读取和操作 XML 的 XML 解析器.解析器把 XML 转换为 XML DOM 对象 (可通过 JavaScript 操作的对象). 一.获取DOM对象 XMLHttpReq ...

  7. 自定义Yaml解析器替换Properties文件

    自定义Yaml解析器替换Properties文件 项目结构 案例代码 配置类SpringConfiguration @Configuration @Import(JdbcCofnig.class) @ ...

  8. Java DOM解析器 - 解析XML文档

    使用DOM的步骤 以下是在使用DOM解析器解析文档使用的步骤. 导入XML相关的软件包. 创建DocumentBuilder 从文件或流创建一个文档 提取根元素 检查属性 检查子元素 导入XML相关的 ...

  9. 死磕Spring之IoC篇 - BeanDefinition 的解析阶段(XML 文件)

    该系列文章是本人在学习 Spring 的过程中总结下来的,里面涉及到相关源码,可能对读者不太友好,请结合我的源码注释 Spring 源码分析 GitHub 地址 进行阅读 Spring 版本:5.1. ...

  10. python解析VOC的xml文件并转成自己需要的txt格式

    在进行神经网络训练的时候,自己标注的数据集往往会有数据量不够大以及代表性不强等问题,因此我们会采用开源数据集作为训练,开源数据集往往具有特定的格式,如果我们想将开源数据集为我们所用的话,就需要对其格式 ...

随机推荐

  1. iOS中 语音识别功能/语音转文字教程详解 韩俊强的博客

    每日更新关注:http://weibo.com/hanjunqiang  新浪微博 原文地址:http://blog.csdn.net/qq_31810357/article/details/5111 ...

  2. Android日历视图(CalendarView)讲解-android学习之旅(三十六)

    CalendarView简介 CalendarView用于显示和选择日期,如果希望监听事件的改变可以用setOnDateChangeListener()方法. CalendarView属性介绍 代码示 ...

  3. 未完成的IT路停在回车键---2014年末总结篇

    时间都去哪儿了?         一晃而过,越来越能体会到这个词的真实感.特别是过了二十岁,这种感觉越来越深刻,越来越强烈,犹如小编做公交车的时候一直向后排排倒的香樟树,还记得有首歌叫时间都哪儿了,而 ...

  4. 【嵌入式开发】 嵌入式开发工具简介 (裸板调试示例 | 交叉工具链 | Makefile | 链接器脚本 | eclipse JLink 调试环境)

    作者 : 韩曙亮 博客地址 : http://blog.csdn.net/shulianghan/article/details/42239705  参考博客 : [嵌入式开发]嵌入式 开发环境 (远 ...

  5. WebLogic重启

     1,用户名密码登录. 2,切换到weblogic的bin目录下  cd bea/user_projects/domains/base_domain/bin/ 3,先停止服务器  ./stopWe ...

  6. 读书笔记 - reword (重来)

    reword (重来) 虽然我是一个不是很喜欢看书的人,但是公认的是看书对提高个人的水平是很有帮助的. 而且我想,如果我要写一本书,我一定会经过多次校验.经过长时间思考确保无误后才会出版的.所以我想看 ...

  7. Java Web 高性能开发,第 2 部分: 前端的高性能

    Web 发展的速度让许多人叹为观止,层出不穷的组件.技术,只需要合理的组合.恰当的设置,就可以让 Web 程序性能不断飞跃.Web 的思想是通用的,它们也可以运用到 Java Web.这一系列的文章, ...

  8. Linux IPC实践(1) -- 概述

    进程的同步与互斥 进程同步: 多个进程需要相互配合共同完成一项任务. 进程互斥: 由于各进程要求共享资源,而且有些资源需要互斥使用,因此各进程间竞争使用这些资源,进程的这种关系为进程的互斥;系统中某些 ...

  9. NSData 与 struct 以及XML的转换。

    在做OC与C++ 混编的时候,我们可能会用到struct 与NSData的相互转换.在这里做一个记录 1.struct转换为NSData 例如如下的struct: struct tagPackageH ...

  10. 【Android 系统开发】Android JNI 之 JNIEnv 解析

    . jni.h文件 : 了解 JNI 需要配合 jni.h 文件, jni.h 是 Google NDK 中的一个文件, 位置是 $/android-ndk-r9d/platforms/android ...