欢迎大家批评指正和转载,不过还是希望大家尊重一下劳动成果,转载注明出处。
转载请注明出处:http://blog.csdn.net/caoshichao520326/article/details/8859822
在解析XML文件的过程中,发现API文档中对于解析事件描述的不够详尽,给解析XML文件带来了不少的困扰,今天做了个事件类型分析的demo和大家分享一下。第一步:新建一个Android工程文件,其他都不用改,只要在onCreate()方法中写一个xmlTest()方法即可,代码如下:
package com.csc.xmltest;
import java.io.IOException;
import org.xmlpull.v1.XmlPullParser;
import org.xmlpull.v1.XmlPullParserException;
import android.app.Activity;
import android.content.res.XmlResourceParser;
import android.os.Bundle;
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
xmlTest();
}
/**
* 测试Pull解析方式中的事件类型
*/
private void xmlTest() {
//定义事件类型
int eventType = 0;
try {
XmlResourceParser xrp = getResources().getXml(R.xml.timezones);
// 获取到xml文件时,XmlResourceParser的是指向文档开始处
eventType = xrp.getEventType();
// System.out.println("-------->"+eventType);//查看事件的数值
while (eventType != XmlPullParser.END_DOCUMENT) {
switch (eventType) {
case XmlPullParser.START_DOCUMENT:
System.out.println("Start document");
break;
case XmlPullParser.START_TAG:
System.out.println("Start tag " + xrp.getName());
break;
case XmlPullParser.TEXT:
System.out.println("Text " + xrp.getText());
break;
case XmlPullParser.END_TAG:
System.out.println("End tag " + xrp.getName());
break;
default:
break;
}
eventType = xrp.next();
//System.out.println("-------->"+eventType);//查看事件的数值
}
} catch (XmlPullParserException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
//判断事件类型是不是文档结束
if (eventType == XmlPullParser.END_DOCUMENT) {
System.out.println("End document");
}
}
}
第二步:上面的代码中用到了一个timezones.xml文件,代码如下,只需将下面代码复制到Android工程文件-->res-->xml文件夹下即可:
<?xml version="1.0" encoding="utf-8"?>
<timezones>
<timezone id="Pacific/Majuro">马朱罗</timezone>
<timezone id="Pacific/Midway">中途岛</timezone>
</timezones>
第三部 :在模拟器上运行程序,在LogCat上可以看到如下信息:
我们对打印结果做分析如下:
1.可以看到Start document打印了两次,说明当程序实例化XmlResourceParser这个对象后,Pull解析器默认的事件是XmlPullParser.START_DOCUMENT,当执行一次XmlResourceParser.next()后,事件仍然指向XmlPullParser.START_DOCUMENT。
2.之后再执行XmlResourceParser.next()则依次向下取一个事件。
3.常用的事件有:XmlPullParser.START_DOCUMENT、XmlPullParser.START_TAG、XmlPullParser.TEXTXmlPullParser.END_TAG、XmlPullParser.END_DOCUMENT。
根据事件的值,就可以解析出xml文档的内容,具体怎么处理数据,就根据大家的需要来编写了。
源码下载地址:http://download.csdn.net/detail/caoshichao520326/5310287
欢迎大家批评指正和转载,不过还是希望大家尊重一下劳动成果,转载注明出处。
转载请注明出处:http://blog.csdn.net/caoshichao520326/article/details/8859822