示例xml
<?xml version="1.0" encoding="UTF-8"?><--start docunemt-->
<persons><--Element node-->
<person id="23">
<name>liming</name>
<age>30</age>
</person>
<person id="20">
<name>zhangxiaoxiao</name>
<age>25</age>
</person>
</persons>
<--end document-->
因为解析属于服务类,所以src里新建一个service包,包中新建一个PersonService类用来写解析过程
需要有对象存储解析的数据,所以src里新建一个domain包,包中新建一个person类用来存储解析的结果
person类中私有化变量,自动添加写入和读取数据方法
package test.domain;
public class Person {
private Integer id;
private String name;
private Integer age;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
}
PersonService
package test.service;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;
import org.xmlpull.v1.XmlPullParser;
import org.xmlpull.v1.XmlPullParserFactory;
import android.util.Xml;
import test.domain.Person;
public class PersonService {
public List<Person> getPersons (InputStream xml) throws Exception//读取输入流,通过这个方法返回一个元素为Person的集合
{
List<Person> persons = null;
Person person = null;
XmlPullParser pullParser = Xml.newPullParser();//通过Android提供的帮助类中,new一个Pull解析器对象
pullParser.setInput(xml, "UTF-8");//为Pull解析器设置要解析的xml数据
int event = pullParser.getEventType();//产生第一个时间,并将其存入event
while(event != XmlPullParser.END_DOCUMENT)//对事件进行判断,在xml文件结束时,结束.next(),不再循环
{
switch(event)//判断该事件
{
case XmlPullParser.START_DOCUMENT://如果对应star document事件
persons = new ArrayList<Person>();//对集合进行初始化
break;
case XmlPullParser.START_TAG:
if("person".equals(pullParser.getName()))//判断解析器读取的节点名称是否是person
{
int id = new Integer (pullParser.getAttributeValue(0));//将读入的数据存入id,因为读到的是字符串,所以用integer转为整形
person = new Person();//实例化person
person.setId(id);//将id存入
}
if("person".equals(pullParser.getName()))//判断解析器读取的节点名称是否是name
{
String name = pullParser.nextText();//通过.next() api取得该节点后的内容
person.setName(name);//将name存入
}
if("age".equals(pullParser.getName()))//判断解析器读取的节点名称是否是name
{
int age =new Integer (pullParser.nextText());//通过.next() api取得该节点后的内容
person.setAge(age);//将age存入
}
case XmlPullParser.END_TAG://判断解析器读到end tag时,对其进行判断。如果为person,将person添加到List集合;如果不是,不需要做处理
if("person".equals(pullParser.getName()))
{
persons.add(person);//向集合中添加一个person
person = null;//将person重置为null
}
break;
}
event = pullParser.next();//对事件进行存储,并进行下一事件的解析
}
return persons;
}
}
注:
解析器在读取xml文件时会一个一个字符读取。当读取的字符符合某一个xml语法时,就会触发对应的事件。所产生的事件实质上是一个数值。
pull解析器在解析完一个事件后,不会主动往后继续解析,如果想要继续解析,必须调用.next()这个api。会使指针指向下一个节点,并触发相应的事件。需要循环调用此api。