用PULL解析器解析XML文件
第一种方式(简洁,直接用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文件的更多相关文章
- 无废话Android之android下junit测试框架配置、保存文件到手机内存、android下文件访问的权限、保存文件到SD卡、获取SD卡大小、使用SharedPreferences进行数据存储、使用Pull解析器操作XML文件、android下操作sqlite数据库和事务(2)
1.android下junit测试框架配置 单元测试需要在手机中进行安装测试 (1).在清单文件中manifest节点下配置如下节点 <instrumentation android:name= ...
- 使用Pull解析器生成XML文件和读取xml文件
有些时候,我们需要生成一个XML文件,生成XML文件的方法有很多,如:可以只使用一个StringBuilder组拼XML内容,然后把内容写入到文件中:或者使用DOM API生成XML文件,或者也可以使 ...
- 使用Pull解析器生成XML文件
有些时候,我们需要生成一个XML文件,生成XML文件的方法有很多,如:可以只使用一个StringBuilder组拼XML内容,然后把内容写入到文件中:或者使用DOM API生成XML文件,或者也可以使 ...
- Android开发8——利用pull解析器读写XML文件
一.基本介绍 对XML解析有SAX和DOM等多种方式,Android中极力推荐xmlpull方式解析xml.xmlpull不仅可用在Android上同样也适用于javase,但在javase环境中需自 ...
- 使用XML序列化器生成XML文件和利用pull解析XML文件
首先,指定XML格式,我指定的XML格式如下: <?xml version='1.0' encoding='utf-8' standalone='yes' ?> <message&g ...
- JavaScript使用浏览器内置XML解析器解析DOM对象
所有现代浏览器都内建了供读取和操作 XML 的 XML 解析器.解析器把 XML 转换为 XML DOM 对象 (可通过 JavaScript 操作的对象). 一.获取DOM对象 XMLHttpReq ...
- 自定义Yaml解析器替换Properties文件
自定义Yaml解析器替换Properties文件 项目结构 案例代码 配置类SpringConfiguration @Configuration @Import(JdbcCofnig.class) @ ...
- Java DOM解析器 - 解析XML文档
使用DOM的步骤 以下是在使用DOM解析器解析文档使用的步骤. 导入XML相关的软件包. 创建DocumentBuilder 从文件或流创建一个文档 提取根元素 检查属性 检查子元素 导入XML相关的 ...
- 死磕Spring之IoC篇 - BeanDefinition 的解析阶段(XML 文件)
该系列文章是本人在学习 Spring 的过程中总结下来的,里面涉及到相关源码,可能对读者不太友好,请结合我的源码注释 Spring 源码分析 GitHub 地址 进行阅读 Spring 版本:5.1. ...
- python解析VOC的xml文件并转成自己需要的txt格式
在进行神经网络训练的时候,自己标注的数据集往往会有数据量不够大以及代表性不强等问题,因此我们会采用开源数据集作为训练,开源数据集往往具有特定的格式,如果我们想将开源数据集为我们所用的话,就需要对其格式 ...
随机推荐
- linux中echo的用法
1.echo命令我们常用的选项有两个,一个是-n,表示输出之后不换行,另外一个是-e,表示对于转义字符按相应的方式处理,如果不加-e那么对于转义字符会按普通字符处理. 2.echo输出时的转义字符 \ ...
- (一〇一)集成静态库RHAddressBook实现OC访问通讯录
使用官方的AddressBook框架仅能使用C语言访问通讯录,十分不便,这里介绍集成第三方框架RHAddressBook的方法,该框架可以通过OC访问和操作通讯录. 该框架是一个静态库,集成比较复杂. ...
- boost::coroutine 无法显示调用栈
boost::coroutine 无法显示调用栈(金庆的专栏)一例因 boost::format() 格式化参数个数错误造成的 coredump,因为使用了 boost::coroutine, 无法显 ...
- MySQL数据库内置函数
mysql数据库中提供了很丰富的函数.mysql函数包括数学函数.字符串函数.日期和时间函数.条件判断函数.系统信息函数.加密函数.格式化函数等.通过这些函数,可以简化用户的操作. 简单介绍几类函数的 ...
- ROS(indigo)机器人操作系统学习有趣丰富的Gazebo仿真示例evarobot
一直在寻找一个示例可以将ROS学习中常用的基础内容大部分都包含进去,最好还包括Gazebo仿真, 这样即使没有硬件设备,也可以很好的学习ROS相关内容,但又必须有对应的硬件,便于后续研究. 这里,介绍 ...
- 【翻译】Ext JS 5:为不同设备设置不同的主题
原文:Sencha Ext JS 5: Supporting Different Themes for Different Devices 步骤1创建一个应用程序 步骤2定义主题 步骤3编辑Appjs ...
- JSP编译成Servlet(四)JSP与Java行关系映射
我们知道java虚拟机只认识class文件,要在虚拟机上运行就必须要遵守class文件格式,所以JSP编译成servlet后还需要进一步编译成class文件,但从JSP文件到java文件再到class ...
- MinerUtil.java 爬虫工具类
MinerUtil.java 爬虫工具类 package com.iteye.injavawetrust.miner; import java.io.File; import java.io.File ...
- C++格式化输出,C++输出格式控制
在输出数据时,为简便起见,往往不指定输出的格式,由系统根据数据的类型采取默认的格式,但有时希望数据按指定的格式输出,如要求以十六进制或八进制形式 输出一个 整数,对输出的小数只保留两位小数等.有两种方 ...
- 更改EBS R12中forms的模式Servlet/Socket
EBS R12中forms的模式有:Servlet mode 和 Forms Socket mode 当我们完成Oracle EBS R12套件的快速安装后,forms的默认配置是Servlet mo ...