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. REGEX例子

    作为REGEX的例子,代码9.3显示了一个给定的文件有多少行,具有给定的模式,通过命令行输入(注:有更有效率的方式来实现这个功能,如Unix下的grep命令,在这里只是给出了另一种方式).这个程序像下 ...

  2. 新手如何在gdb中存活

    网络上已经有很多gdb调试的文章了,为什么我还要写这篇文章呢,因为本文是写给gdb新手的,目的就是通过一个简单的例子来让新手很快上手.一旦上手入门了,其他的问题就可以自己去搜索搞定了.右边是gdb的L ...

  3. MapReduce剖析笔记之八: Map输出数据的处理类MapOutputBuffer分析

    在上一节我们分析了Child子进程启动,处理Map.Reduce任务的主要过程,但对于一些细节没有分析,这一节主要对MapOutputBuffer这个关键类进行分析. MapOutputBuffer顾 ...

  4. mac 无法识别seagate硬盘、无法向其写入文件

    1,无法识别 Seagate 硬盘 新买的mac air Captian 10.11.6系统,连上硬盘根本不出现盘符,usb插头不要插得太深,慢慢的插入,看到硬盘白灯亮起就可以了 2,无法向 Seag ...

  5. .NetCore之EF跳过的坑

    我在网上看到很多.netCore的信息,就动手自己写一个例子测试哈,但是想不到其中这么多坑: 1.首先.netCore和EF的安装就不用多说了,网上有很多的讲解可以跟着一步一步的下载和安装,但是需要注 ...

  6. ASP.NET OAuth:access token的加密解密,client secret与refresh token的生成

    在 ASP.NET OWIN OAuth(Microsoft.Owin.Security.OAuth)中,access token 的默认加密方法是: 1) System.Security.Crypt ...

  7. Android 自定义View及其在布局文件中的使用示例

    前言: 尽管Android已经为我们提供了一套丰富的控件,如:Button,ImageView,TextView,EditText等众多控件,但是,有时候在项目开发过程中,还是需要开发者自定义一些需要 ...

  8. 前端学HTTP之连接管理

    前面的话 HTTP连接是HTTP报文传输的关键通道.要掌握HTTP就需要理解HTTP连接的来龙去脉以及如何使用这些连接 如果想查看一个网页,浏览器收到URL时,会执行下图所示的步骤.将服务器的IP地址 ...

  9. 已经重写,源码和文章请跳转http://www.cnblogs.com/ymnets/p/5621706.html

    文章由于写得比较仓促 已经重写,源码和文章请跳转 http://www.cnblogs.com/ymnets/p/5621706.html 系列目录 前言: 导入导出实在多例子,很多成熟的组建都分装了 ...

  10. 面向对象的JS(一)

    JavaScript是弱类型,可变性强 /*JavaScript和其他的语言类似,也是面向对象,自然也就是存在类和对象(对象是类的实例化)*/ //1.JS对象 var empty = {}; //没 ...