加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

用PULL解析XML文件时循环的过程

发布时间:2020-12-16 08:20:47 所属栏目:百科 来源:网络整理
导读:XML文件内容如下(名字为"teacher.xml") ?xml version="1.0" encoding="UTF-8"? teachers teacher namezhangsan/name age19/age money12000/money /teacher teacher namelisi/name age23/age money8000/money /teacher /teachers 使用PULL解析XML文件的代码

XML文件内容如下(名字为"teacher.xml")
<?xml version="1.0" encoding="UTF-8"?>
<teachers>
<teacher>
<name>zhangsan</name>
<age>19</age>
<money>12000</money>
</teacher>
<teacher>
<name>lisi</name>
<age>23</age>
<money>8000</money>
</teacher>
</teachers>

使用PULL解析XML文件的代码:

import java.io.FileReader;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;

import org.xmlpull.v1.XmlPullParser;
import org.xmlpull.v1.XmlPullParserException;
import org.xmlpull.v1.XmlPullParserFactory;

public class PullTry {

	public static void main(String[] args) {
		List<Teacher> datas = null;
		Teacher teacher = null;

		try {
			XmlPullParserFactory factory = XmlPullParserFactory.newInstance();

			XmlPullParser parser = factory.newPullParser();

			parser.setInput(new FileReader("teacher.xml"));

			int eventType = parser.getEventType();

			while (eventType != XmlPullParser.END_DOCUMENT) {
				String tagName = parser.getName();
				switch (eventType) {
				case XmlPullParser.START_DOCUMENT:
					// 创建list
					datas = new ArrayList<>();
					break;
				case XmlPullParser.START_TAG:
					// 创建Teacher对象
					if ("teacher".equals(tagName)) {
						teacher = new Teacher();
					} else if ("name".equals(tagName)) {
						teacher.setName(parser.nextText());
					} else if ("age".equals(tagName)) {
						teacher.setAge(Integer.parseInt(parser.nextText()));
					} else if ("money".equals(tagName)) {
						teacher.setMoney(Double.parseDouble(parser.nextText()));
					}
					break;
				case XmlPullParser.END_TAG:
					// 把对象添加进List集合中
					if ("teacher".equals(tagName)) {
						datas.add(teacher);
					}
					break;

				default:
					break;
				}

				// 将eventType指向下一步...
				eventType = parser.next();
			}
		} catch (XmlPullParserException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		}
		for (int i = 0; i < datas.size(); i++) {
			System.out.println(datas.get(i));
		}
		
		System.out.println(count);

	}

}

这里主要看while循环内部是如何读取xml文件的..

首先循环的条件是eventType != XmlPullParser.END_DOCUMENT

如果eventType不等于XmlPullParser.END_DOCUMENT,就进行下一次循环。这里eventType的值有11种,但用到的只有前5种。

public static final int START_DOCUMENT = 0;

public static final int END_DOCUMENT = 1;

public static final int START_TAG = 2;

public static final int END_TAG = 3;

public static final int TEXT = 4;

为了观察循环执行的过程,我在循环内添加了一行代码:
System.out.println(eventType+"===第"+count+"次循环==="+tagName);

其中count是循环运行的次数。添加这行代码后控制台显示出如下信息:

0===第1次循环===null
2===第2次循环===teachers
4===第3次循环===null
2===第4次循环===teacher
4===第5次循环===null
2===第6次循环===name
4===第7次循环===null
2===第8次循环===age
4===第9次循环===null
2===第10次循环===money
4===第11次循环===null
3===第12次循环===teacher
4===第13次循环===null
2===第14次循环===teacher
4===第15次循环===null
2===第16次循环===name
4===第17次循环===null
2===第18次循环===age
4===第19次循环===null
2===第20次循环===money
4===第21次循环===null
3===第22次循环===teacher
4===第23次循环===null
3===第24次循环===teachers
Teacher [name=zhangsan,age=19,money=12000.0]
Teacher [name=lisi,age=23,money=8000.0]
24

先说一下,只有在下一次eventType值为4(也即下一次循环时读取了TEXT)的情况下,读取的内容parser.nextText()不为空

????结合xml文件来看,可以得出结论:

第一次循环,eventType值为0,也即START_DOCUMENT的情况。此时tagName值为空。

第二次循环,eventType值为2,也即START_TAG的情况。此时tagName值为teachers。也就是说此时读取到了<teachers>这个标签。由于下一次eventType值为4,也即TEXT的情况,所以此次读取的内容parser.nextText()值为<teachers>标签到<teacher>标签中间的文本内容!也就是一个n加一个t。

第三次循环,eventType值为4,也即TEXT的情况。此时tagName值为空。

第四次循环,eventType值为2,也即START_TAG的情况。此时tagName值为teacher。也就是说此时读取到了<teacher>这个标签。注意:此时if语句判断出"teacher".equals(tagName)返回值为true,会执行下面的teacher = new Teacher();来创建一个Teacher类的对象。由于下一次eventType值为4,也即TEXT的情况,所以此次读取的内容parser.nextText()值为<teacher>标签到<name>标签中间的文本内容,也就是一个n加两个t。

第五次循环,eventType值为4,也即TEXT的情况。此时tagName值为空。

第六次循环,eventType值为2,也即START_TAG的情况。此时tagName值为name。也就是说此时读取到了<name>这个标签。注意:此时if语句判断出"name".equals(tagName)返回值为true,会执行下面的teacher.setName(parser.nextText());,这里的parser.nextText()值应该是zhangsan。这样就把zhangsan赋值给了这个teacher对象的name属性。

第七次循环,eventType值为4,也即TEXT的情况。此时tagName值为空。

后面好像不用讲什么了,都是一个意思。

ps: 每一次遇到一个Teacher标签(Teacher标签是一个子标签,Teachers是父标签)都会创建一个对象,接着把里面的孙标签(name、age和money)赋值到这个对象的属性中。

ps2: 这个例子中孙标签中的endtag不会被读取。(就是</name>这种..)

xbox: eventType值为3的情况只有三种,这三种情况下tagName值分别为teacher、teacher和teachers。进一步说明了ps2是对的.....

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读