您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

使用PULL解析XML文件时循环过程的示例代码分享

2024/4/15 5:40:45发布29次查看
xml文件内容如下(名字为teacher.xml) 44268761adfa814cf615c226dea79439 zhangsan 1912000 lisi 23 8000使用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: // 创建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。也就是说此时读取到了这个标签。由于下一次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文件时循环过程的示例代码分享的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product