现在的位置: 首页 > 综合 > 正文

关于Android的XML文件解析器Pull解析方式事件类型的分析

2017年12月01日 ⁄ 综合 ⁄ 共 2360字 ⁄ 字号 评论关闭

      欢迎大家批评指正和转载,不过还是希望大家尊重一下劳动成果,转载注明出处。

    转载请注明出处: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

抱歉!评论已关闭.