pull解析xml文件

1.获得XmlpullParser类的引用

    这里有两种方法

 //解析器工厂
XmlPullParserFactory factory=XmlPullParserFactory.newInstance();
XmlPullParser pullParser=factory.newPullParser(); //直接获得实例
XmlPullParser pullParser= Xml.newPullParser();

2.设置解析内容

通过setInput方法设置解析内容   重载写的很清楚  把xml文件读取到Reader  或  InputStream中  注意  InputStream需要指定编码

 pullParser.setInput(getAssets().open("student.xml"),"utf-8");

getAssets().open("student.xml")返回一个字节流InputStream 所以需要指定编码格式

3.获取当前的事件类型 开始解析

  START_DOCUMENT 开始读取文档

  END_DOCUMENT  结束读取文档

  START_TAG  开始读取标签

  END_TAG    结束读取标签

xml数据

 <?xml version="1.0" encoding="UTF-8" ?>
<persons>
<person id="1">
<name>张三</name>
<age>23</age>
</person>
<person id="2">
<name>李四</name>
<age>23</age>
</person>
</persons>

pull解析核心代码

  try {
//解析器工厂
XmlPullParserFactory factory=XmlPullParserFactory.newInstance();
//创建解析器
XmlPullParser pullParser=factory.newPullParser();
//直接创建解析器 //pullParser= Xml.newPullParser();
//设置解析内容
//getAssets().open("student.xml")返回一个字节流InputStream 所以需要指定编码格式
pullParser.setInput(getAssets().open("student.xml"),"utf-8");
//开始解析
//获取当前解析的标签
//获取当前事件类型:开始读取文档,开始读取标签,结束标签,结束读取文档 类似一个状态
int type=pullParser.getEventType();
while (type!=XmlPullParser.END_DOCUMENT){
switch (type){
//开始读取文档
case XmlPullParser.START_DOCUMENT:
break;
//开始读取标签
case XmlPullParser.START_TAG:
String tag=pullParser.getName();//获取节点名
if(tag.equals("person")){
person=new Person();
//获取节点属性
String id=pullParser.getAttributeValue("","id");
if (TextUtils.isEmpty(id)) continue;
person.setId(Integer.parseInt(id));
}else if(tag.equals("name")){
//获取下一个文本
String name=pullParser.nextText();
if (TextUtils.isEmpty(name)) continue;
person.setName(name);
}else if(tag.equals("age")){
String age=pullParser.nextText();
if (TextUtils.isEmpty(age)) continue;
person.setAge(Integer.parseInt(age));
}
break;
//结束读取标签
case XmlPullParser.END_TAG:
tag=pullParser.getName();
//当一个person 读取完成之后 添加到list
if(tag.equals("person")){
persons.add(person);
}
break;
//结束读取文档
case XmlPullParser.END_DOCUMENT:
break;
}
//读取下一个事件
type=pullParser.next();
}
} catch (XmlPullParserException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}

这里提一下getAttributeValue()方法 获取节点属性 有两个参第一个参数代表的是命名空间 什么xml是里的命名空间呢 一般xml文件根元素附加都会有xmlns 这就定义命名空间的

给属性添加命名空间后  就表示是那个命名空间的属性 类似包名  不过不常用 

  SAX解析xml数据
  sax对文档进行顺序扫描 当扫描到
文档开始结束,元素开始结束,标签开始结束都会触发事件
  sax的使用和pull差不多 个人喜欢用sax多一点,sax采用的事件驱动
  sax是通过重写方法来实现,符合条件就会触发回调 这些方法都是定义在ContentHandler接口中,Android为我们提供了一个帮助类
DefaultHandler,只需要继承这个类,重写方法就ok
核心代码
  
 1        try {
//创建SAX解析器
SAXParserFactory factory=SAXParserFactory.newInstance();
SAXParser parser= factory.newSAXParser();
//自定一个Handler解析器
PersonHandler handler=new PersonHandler();
//解析器对xml进行解析
parser.parse(getAssets().open("student.xml"),handler);
for(Person p:handler.getPersonList()){
Log.e("XmlSAXParser",p.getName()+"====="+p.getAge()+"=========="+p.getId());
}
} catch (ParserConfigurationException e) {
e.printStackTrace();
} catch (SAXException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
解析器代码

 public class PersonHandler extends DefaultHandler {
//保存数据
private List<Person> personList;
private Person person;
//节点名称 当前解析的元素名
private String tag; /**
* 处理xml文件中读到到文本内容
* @param ch 字符串内容
* @param start 起始位置
* @param length 长度
* @throws SAXException
*/
@Override
public void characters(char[] ch, int start, int length) throws SAXException {
super.characters(ch, start, length);
//创建成字符串
String text=new String(ch,start,length).trim();
//字符串不能为空,既不读取空的文本节点,如换行
if(TextUtils.isEmpty(text)) return;
//当节点名称等于name时赋值
if("name".equals(tag)){
person.setName(text);
}else if("age".equals(tag)){
person.setAge(Integer.parseInt(text));
}
} /**
*
* @param uri 命名空间 没啥用
* @param localName 前缀标签名 没啥用
* @param qName 节点名字
* @param attributes 属性集合
* @throws SAXException
*/
@Override//qName attributes
public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException {
super.startElement(uri, localName, qName, attributes);
tag=qName;
//为什么创建集合 和对象 请看上面的xml 仔细分析
if("persons".equals(qName)){
//数据存储的集合
personList=new ArrayList<>();
}else if("person".equals(qName)){
person=new Person();
String id=attributes.getValue("id");
if (!TextUtils.isEmpty(id)){
person.setId(Integer.parseInt(id));
}
}
} @Override
public void endElement(String uri, String localName, String qName) throws SAXException {
super.endElement(uri, localName, qName);
if("person".equals(qName)){
personList.add(person);
}
} }
还有startElement   startDocument endDocument等方法    

过几天会整理一个xml和listview的简单使用的Demo

Android 使用pull,sax解析xml的更多相关文章

  1. Dom,pull,Sax解析XML

    本篇随笔将详细讲解如何在Android当中解析服务器端传过来的XML数据,这里将会介绍解析xml数据格式的三种方式,分别是DOM.SAX以及PULL. 一.DOM解析XML 我们首先来看看DOM(Do ...

  2. Android之SAX解析XML

    一.SAX解析方法介绍 SAX(Simple API for XML)是一个解析速度快并且占用内存少的XML解析器,非常适合用于Android等移动设备. SAX解析器是一种基于事件的解析器,事件驱动 ...

  3. Android SAX解析XML

    本篇讲解一下SAX解析XML这种方式,首先来看一下它的基本介绍: SAX是一种以事件驱动的XML API,由它定义的事件流可以指定从解析器传到专门的处理程序的代码的XML结构,简单的讲,它是种解析速度 ...

  4. cocos2d-x 3.0 使用Sax解析xml文件(中国显示器问题解决)

    今天是个好日子.我以为事情可以变得,明天是个好日子.打开门儿春风... 恩,听着歌写文档生活就是这么享受. 今天曾经的邻居大神突然在qq上赞了我一下,这让我异常激动啊.. 这还要从前前前几天说起,那会 ...

  5. SAX解析xml浅析

    SAX解析XML文件采用事件驱动的方式进行,也就是说,SAX是逐行扫描文件,遇到符合条件的设定条件后就会触发特定的事件,回调你写好的事件处理程序.使用SAX的优势在于其解析速度较快,占用内存较少(相对 ...

  6. 安卓SAX解析XML文件

    XML文件经常使用的解析方式有DOM解析,SAX解析. 一.Sax SAX(simpleAPIforXML)是一种XML解析的替代方法. 相比于DOM.SAX是一种速度更快,更有效的方法. 它逐行扫描 ...

  7. sax解析xml文件的DefaultHandler处理类

    一千年的时光,我无数次掀起岁月的帷幔,只为和你,在某一个平静如水的日子相遇,然后相识,倾情一生,缱绻一世,好美的散文,好吧,我情愿把这个“你”当作android:),使用sax解析xml文件是我见到过 ...

  8. JAVA使用SAX解析XML文件

    在我的另一篇文章(http://www.cnblogs.com/anivia/p/5849712.html)中,通过一个例子介绍了使用DOM来解析XML文件,那么本篇文章通过相同的XML文件介绍如何使 ...

  9. DOM&SAX解析XML

    在上一篇随笔中分析了xml以及它的两种验证方式.我们有了xml,但是里面的内容要怎么才能得到呢?如果得不到的话,那么还是没用的,解析xml的方式主要有DOM跟SAX,其中DOM是W3C官方的解析方式, ...

随机推荐

  1. Maven实战:pom.xml与settings.xml

    pom.xml与settings.xml pom.xml与setting.xml,可以说是Maven中最重要的两个配置文件,决定了Maven的核心功能,虽然之前的文章零零碎碎有提到过pom.xml和s ...

  2. C#与C++的发展历程第二 - C#4.0再接再厉

    系列文章目录 1. C#与C++的发展历程第一 - 由C#3.0起 2. C#与C++的发展历程第二 - C#4.0再接再厉 开始本系列的第二篇,这篇文章中将介绍C#4.0中一些变化,如C++有类似功 ...

  3. C++ std::queue

    std::queue template <class T, class Container = deque<T> > class queue; FIFO queue queue ...

  4. 通过easyui tab添加的子页面JS脚本必须放在body才生效

    通过easyui tab添加的子页面JS脚本必须放在body才生效 可通过Chrome查看元素时,head标签是否含有你自己写的JS代码

  5. 初探AngularJS

    一.前言 早已听说AngularJS的大名,并在很久前也编写过些小demo,但是都没有系统学习过.由于,在下个版本项目中用到了AngularJS,so,那就一起再来研究研究呗. 说到,这个Angula ...

  6. YYModel 源码解读(二)之YYClassInfo.h (2)

    /** Instance variable information. */ @interface YYClassIvarInfo : NSObject @property (nonatomic, as ...

  7. JQuery中ajax的相关方法总结

    前提条件 话说是jquery中的ajax方法,那么前提条件当然是引入jquery啦. <script src="http://libs.baidu.com/jquery/1.9.0/j ...

  8. CSS3属性 box-shadow 向框添加一个或多个阴影

    CSS3属性 利用box-shadow制作网页页眉背景 box-shadow 浏览器支持 IE9+.Firefox 4.Chrome.Opera 以及 Safari 5.1.1 支持 box-shad ...

  9. FFmpeg学习5:多线程播放视音频

    在前面的学习中,视频和音频的播放是分开进行的.这主要是为了学习的方便,经过一段时间的学习,对FFmpeg的也有了一定的了解,本文就介绍了 如何使用多线程同时播放音频和视频(未实现同步),并对前面的学习 ...

  10. 完美解决,浏览器下拉显示网址问题 | 完美解决,使用原生 scroll 写下拉刷新

    在 web 开发过程中我们经常遇到,不想让用户下拉看到我的地址,也有时候在 div 中没有惯性滚动,就此也出了 iScroll 这种关于滚动条的框架,但是就为了一个体验去使用一个框架好像又不值得,今天 ...