待解析的xml报文如下:
<?xml version="1.0" encoding="UTF-8"?>
<persons>
<person id="23">
<name>李明xxx</name>
<age>23ccc</age>
</person>
<person id="22">
<name>李量fff</name>
<age>25www</age>
</person>
</persons>
解析的java代码
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;
import org.xmlpull.v1.XmlPullParser;
import android.util.Xml;
import com.leequer.Doem.Person;
/**
* 使用pull解析xml
* 2010-04-26
* @author leequer
*
*/
public class ReadXmlByPullService {
public static List<Person> ReadXmlByPull (InputStream inputStream)throws Exception
{
List <Person> personList = null;
/**
* android给我们提供了xml 用来得到xmlpull解析器
*/
XmlPullParser xmlpull = Xml.newPullParser();
/**
* 将输入流传入 设定编码方式
*
*/
xmlpull.setInput(inputStream, "utf-8");
/**
* pull读到xml后 返回数字
* 读取到xml的声明返回数字0 START_DOCUMENT;
读取到xml的结束返回数字1 END_DOCUMENT ;
读取到xml的开始标签返回数字2 START_TAG
读取到xml的结束标签返回数字3 END_TAG
读取到xml的文本返回数字4 TEXT
*/
int eventCode = xmlpull.getEventType();
/**
* 只要这个事件返回的不是1 我们就一直读取xml文件
*/
Person person = null;
while(eventCode!=XmlPullParser.END_DOCUMENT)
{
switch (eventCode)
{
case XmlPullParser.START_DOCUMENT:
{//开始文档 new数组
personList =new ArrayList<Person>();
break;
}
case XmlPullParser.START_TAG:
{
if("person".equals(xmlpull.getName()))
{
person = new Person();
person.setId(xmlpull.getAttributeValue(0));
}else if (person!=null)
{
if(("name".equals(xmlpull.getName())))
{
/**
* 如果当前元素的下一个元素是文本节点 就可以直接用nextText()这个方法来得到文本节点的内容
*/
person.setName(xmlpull.nextText());
}else if ("age".equals(xmlpull.getName()))
{
/**
* 如果当前元素的下一个元素是文本节点 就可以直接用nextText()这个方法来得到文本节点的内容
*/
person.setAge(xmlpull.nextText());
}
}
break;
}
case XmlPullParser.END_TAG:
{
if("person".equals(xmlpull.getName())&&person!=null)
{
personList.add(person);
person = null;
}
break;
}
}
eventCode = xmlpull.next();//没有结束xml文件就推到下个进行解析
}
return personList;
}
}