之前的两篇文章,主要是用于生成xml文件,有生成比然会有xml解析。在Android中我们可以使用dom、sax等java的解析方式,但我们使用Android提供的pull解析方式来解析xml文件。
1、通过 Xml.newPullParser()创建解析器
2、通过setInput制定输入流和编码格式
3、getEventType()获取当前结点类型
XmlPullParser.START_DOCUMENT , XmlPullParser.END_DOCUMENT, XmlPullParser.START_TAG ,XmlPullParser.END_TAG
4、getName()获取当前节点的名字
5、nextText()获取当前节点的下一个节点的文本
public void click(View v){
//获取到src文件夹下的资源文件
InputStream is = getClassLoader().getResourceAsStream("sms.xml");
//拿到pull解析器对象
XmlPullParser xp = Xml.newPullParser();
//初始化
try {
xp.setInput(is, "utf-8");
//获取当前节点的事件类型,通过事件类型的判断,
//我们可以知道当前节点是什么节点,从而确定我们应该做什么操作
int type = xp.getEventType();
Message msg = null;
while(type != XmlPullParser.END_DOCUMENT){
//根据节点的类型,要做不同的操作
switch (type) {
case XmlPullParser.START_TAG:
// 获取当前节点的名字
if("message".equals(xp.getName())){
//创建msg集合对象,用于存放msg的javabean
cityList = new ArrayList<Message>();
}
else if("sms".equals(xp.getName())){
//创建msg的javabean对象
msg = new Message();
}
else if("body".equals(xp.getName())){
// 获取当前节点的下一个节点的文本
String body = xp.nextText();
msg.setName(body);
}
else if("date".equals(xp.getName())){
// 获取当前节点的下一个节点的文本
String date = xp.nextText();
msg.setTemp(date);
}
else if("type".equals(xp.getName())){
// 获取当前节点的下一个节点的文本
String type = xp.nextText();
msg.setPm(type);
}else if("address".equals(xp.getName())){
// 获取当前节点的下一个节点的文本
String address = xp.nextText();
msg.setPm(address);
}
break;
case XmlPullParser.END_TAG:
if("msg".equals(xp.getName())){
//把city的javabean放入集合中
cityList.add(msg);
}
break;
}
//把指针移动到下一个节点,并返回该节点的事件类型
type = xp.next();
}
for (City c : cityList) {
System.out.println(c.toString());
}
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}