使用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 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:// 创建listdatas = 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。也就是说此时读取到了这个标签。由于下一次eventType值为4,也即TEXT的情况,所以此次读取的内容parser.nextText()值为标签到标签中间的文本内容!也就是一个/n加一个/t。
第三次循环,eventType值为4,也即TEXT的情况。此时tagName值为空。
第四次循环,eventType值为2,也即START_TAG的情况。此时tagName值为teacher。也就是说此时读取到了这个标签。注意:此时if语句判断出"teacher".equals(tagName)返回值为true,会执行下面的teacher = new Teacher();来创建一个Teacher类的对象。由于下一次eventType值为4,也即TEXT的情况,所以此次读取的内容parser.nextText()值为标签到标签中间的文本内容,也就是一个/n加两个/t。
第五次循环,eventType值为4,也即TEXT的情况。此时tagName值为空。
第六次循环,eventType值为2,也即START_TAG的情况。此时tagName值为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不会被读取。(就是这种..)
xbox: eventType值为3的情况只有三种,这三种情况下tagName值分别为teacher、teacher和teachers。进一步说明了ps2是对的.....
更多相关文章
- XML文件要有根标签(错误)的代码解决分享
- cdata标签如何使用
- 最新·前端的工资分布情况 - 你拖后腿了吗?
- 解决matplotlib文字标签遮挡问题
- 我用python掐指一算,2020高考分数和录取情况可能是这样
- 怎么循环查看php-fpm的内存占用情况
- PHP获取不到SESSION信息之一般情况解决方案
- @Transactional 注解哪些情况下会失效?
- 别在不知道临时死区的情况下使用 JavaScript 变量[每日前端夜话0