实现XML解析有很多库,有DOM,有SAX,还有其它的。为了为后面android程序中解析XML做基础,我只学习了SAX解析XML;
概述:
http://www.sf.org.cn/article/base/200707/20374.html
SAX (Simple API for XML) 和 DOM (Document Object Model) 是当前两个主要的XML API,几乎所有商用的xml 解析器都同时实现了这两个接口。因此如果你的程序使用了SAX或者DOM APIs,那么你的程序对xml解析器是透明。
1. DOM以一个分层的对象模型来映射xml文档。而SAX将文档中的元素转化为对象来处理。
2. DOM将文档载入到内存中处理,而SAX则相反,它可以检测一个即将到来的 XML流,由此并不需要所有的XML代码同时载入到内存中。
程序实现过程:
1.新建一个工厂类spf;
2.从工厂类中产生一个SAX实例:即SAX的解析类SAXParser
3.从SAXParser调用parse方法对xml文件进行解析;
完整代码如下:
测试XML:test.xml如下,放在工程文件顶层就好了
测试结果如下:
~~~~解析文档开始~~~
startElement处标签名:student
startElement处标签名:person
id = 0001
sex = 男
startElement处标签名:name
endElement处的值是:张三
startElement处标签名:age
endElement处的值是:25
startElement处标签名:college
endElement处的值是:工商管理学院
startElement处标签名:telephone
endElement处的值是:6666666
endElement处的值是:
startElement处标签名:person
id = 0002
sex = 女
startElement处标签名:name
endElement处的值是:李四
startElement处标签名:age
endElement处的值是:26
startElement处标签名:college
endElement处的值是:医学院
startElement处标签名:telephone
endElement处的值是:8888888
endElement处的值是:
startElement处标签名:person
id = 0003
startElement处标签名:name
endElement处的值是:王五
startElement处标签名:age
endElement处的值是:26
startElement处标签名:college
endElement处的值是:医学院
startElement处标签名:telephone
endElement处的值是:8888888
endElement处的值是:
endElement处的值是:
~~~~解析文档结束~~~
共用2898187纳秒
startElement处标签名:student
startElement处标签名:person
id = 0001
sex = 男
startElement处标签名:name
endElement处的值是:张三
startElement处标签名:age
endElement处的值是:25
startElement处标签名:college
endElement处的值是:工商管理学院
startElement处标签名:telephone
endElement处的值是:6666666
endElement处的值是:
startElement处标签名:person
id = 0002
sex = 女
startElement处标签名:name
endElement处的值是:李四
startElement处标签名:age
endElement处的值是:26
startElement处标签名:college
endElement处的值是:医学院
startElement处标签名:telephone
endElement处的值是:8888888
endElement处的值是:
startElement处标签名:person
id = 0003
startElement处标签名:name
endElement处的值是:王五
startElement处标签名:age
endElement处的值是:26
startElement处标签名:college
endElement处的值是:医学院
startElement处标签名:telephone
endElement处的值是:8888888
endElement处的值是:
endElement处的值是:
~~~~解析文档结束~~~
共用2898187纳秒