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

这篇文章给大家分享的是有关使用PULL解析XML文件时循环过程的案例的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

XML文件内容如下(名字为"teacher.xml") <?xml version="1.0" encoding="UTF-8"?> zhangsan 1912000 lisi 23 8000使用PULL解析XML文件的代码:

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

importjava.io.FileReader;
importjava.io.IOException;
importjava.util.ArrayList;
importjava.util.List;
importorg.xmlpull.v1.XmlPullParser;
importorg.xmlpull.v1.XmlPullParserException;
importorg.xmlpull.v1.XmlPullParserFactory;
publicclassPullTry{
publicstaticvoidmain(String[]args){
Listdatas=null;
Teacherteacher=null;
try{
XmlPullParserFactoryfactory=XmlPullParserFactory.newInstance();
XmlPullParserparser=factory.newPullParser();
parser.setInput(newFileReader("teacher.xml"));
inteventType=parser.getEventType();
while(eventType!=XmlPullParser.END_DOCUMENT){
StringtagName=parser.getName();
switch(eventType){
caseXmlPullParser.START_DOCUMENT:
//创建list
datas=newArrayList<>();
break;
caseXmlPullParser.START_TAG:
//创建Teacher对象
if("teacher".equals(tagName)){
teacher=newTeacher();
}elseif("name".equals(tagName)){
teacher.setName(parser.nextText());
}elseif("age".equals(tagName)){
teacher.setAge(Integer.parseInt(parser.nextText()));
}elseif("money".equals(tagName)){
teacher.setMoney(Double.parseDouble(parser.nextText()));
}
break;
caseXmlPullParser.END_TAG:
//把对象添加进List集合中
if("teacher".equals(tagName)){
datas.add(teacher);
}
break;
default:
break;
}
//将eventType指向下一步...
eventType=parser.next();
}
}catch(XmlPullParserExceptione){
e.printStackTrace();
}catch(IOExceptione){
e.printStackTrace();
}
for(inti=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种。

publicstaticfinalintSTART_DOCUMENT=0;
publicstaticfinalintEND_DOCUMENT=1;
publicstaticfinalintSTART_TAG=2;
publicstaticfinalintEND_TAG=3;
publicstaticfinalintTEXT=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次循环===teachersTeacher[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是对的.....

感谢各位的阅读!关于“使用PULL解析XML文件时循环过程的案例”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

发布于 2021-03-13 15:40:31
收藏
分享
海报
0 条评论
163
上一篇:怎么使用XML化的思维组织数据 下一篇:怎么使用XML Schema定义元素
目录

    0 条评论

    本站已关闭游客评论,请登录或者注册后再评论吧~

    忘记密码?

    图形验证码