用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格式
在进行神经网络训练的时候,自己标注的数据集往往会有数据量不够大以及代表性不强等问题,因此我们会采用开源数据集作为训练,开源数据集往往具有特定的格式,如果我们想将开源数据集为我们所用的话,就需要对其格式 ...
随机推荐
- 安卓java.lang.IllegalStateException: The specified child already has a parent.解决方案
在使用ViewPager的时候遇到一个错误java.lang.IllegalStateException: The specified child already has a parent. You ...
- 【Shader拓展】Illustrative Rendering in Team Fortress 2
写在前面 早在使用ramp texture控制diffuse光照一文就提到了这篇著名的论文.Valve公司发表的其他成果可见这里.这是Valve在2007年发表的一篇非常具有影响力的文章,我的导师也提 ...
- Linux内核2.6的进程调度
Linux是多任务抢占操作系统,多任务就是指多个进程间通过分时切换来并发执行.非抢占的系统是对每个进程而言,除非时间片用完或主动放弃否则不会被剥夺CPU,主动放弃包括调用一些调度的系统调用( ...
- UNIX环境高级编程——线程属性之并发度
并发度控制着用户级线程可以映射的内核线程或进程的数目.如果操作系统的实现在内核级的线程和用户级的线程之间保持一对一的映射,那么改变并发度并不会有什么效果,因为所有的用户级线程都可能被调度到.但是,如果 ...
- Android PackageManager源码浅析以及静默安装实现方式
Aandroid应用管理 >http://blog.csdn.net/sk719887916/article/details/50314017 skay整理. >201 ...
- UNIX环境高级编程——守护进程
一.守护进程简介 守护进程,也就是通常说的Daemon进程,是Linux中的后台服务进程.它是一个生存期较长的进程,通常独立于控制终端并且周期性地执行某种任务或等待处理某些发生的事件.守护进程常常在系 ...
- (NO.00003)iOS游戏简单的机器人投射游戏成形记(十六)
回到MainScene.m中添加selectRobot方法: -(void)selectRobot:(Robot *)robot{ LevelRestrict *lr = [LevelRestrict ...
- Socket编程实践(3) --Socket API
socket函数 #include <sys/types.h> #include <sys/socket.h> int socket(int domain, int type, ...
- Touch Handling in Cocos2D 3.x(七)
在touchMoved方法中寻找触摸在父节点(CCScene)中的位置并且移动CCDragSprite到其父节点的相应位置中去. 在我们在动作中观赏拖放机制之前,我们需要使用这个新实现的类.打开Mai ...
- Net和Java基于zipkin的全链路追踪
在各大厂分布式链路跟踪系统架构对比 中已经介绍了几大框架的对比,如果想用免费的可以用zipkin和pinpoint还有一个忘了介绍:SkyWalking,具体介绍可参考:https://github. ...