sax解析分为以下几步:
1 获取一个saxparserfactory
2 获取一个解析器
3 创建handler对象,这个myHandler是继承了DefaultHandler的一个类,这个实现类里写具体的解析逻辑
4 开始解析xml。
结构层次图:
具体如下面的代码:
mySAXparser:
package com.imooc.test; import java.io.IOException; import javax.xml.parsers.ParserConfigurationException;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory; import org.xml.sax.SAXException; public class mySAXparser {
public static void main(String[] args) {
//1 获取一个saxparserfactory
SAXParserFactory factory = SAXParserFactory.newInstance();
try {
//2 获取一个解析器
SAXParser parser = factory.newSAXParser();
/*
* 3 创建handler对象,这个myHandler是继承了DefaultHandler的一个类
* 这个实现类里写具体的解析逻辑
*/
myHandler handler = new myHandler();
//4 开始解析xml,
parser.parse("books.xml",handler); } catch (ParserConfigurationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SAXException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
myHandler:
package sax; import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler; public class myHandler extends DefaultHandler {
int i =0;
int j = 0;
String value = null;
@Override
public void startDocument() throws SAXException {
// TODO Auto-generated method stub
super.startDocument();
System.out.println("startDocument开始解析.............."); } @Override
public void endDocument() throws SAXException {
// TODO Auto-generated method stub
super.endDocument();
System.out.println("endDocument结束解析............");
} @Override
public void startElement(String uri, String localName, String qName,
Attributes attributes) throws SAXException {
// TODO Auto-generated method stub
super.startElement(uri, localName, qName, attributes);
/*
* qName:The qualified name (with prefix),
* or the empty string if qualified names are not available.
* qName:实际上就是标签名的名字,如<sex>1</sex> 那么qName就代指的这个标签名,sex
*
*/
if(qName.equals("book")){
i++;
String value = attributes.getValue("size");
int len = attributes.getLength();
System.out.println("len:"+len);
for(int k=0;k<len;k++){
int m = k+1;
System.out.println("属性"+m+":"+attributes.getQName(k));
}
System.out.println("book.size:"+value);
System.out.println("第"+i+"处,解析到book元素的标签。。。");
}
if(qName.equals("bookstore")){
j++;
System.out.println("第"+j+"处,解析到bookstore元素的标签。。。");
} } @Override
public void endElement(String uri, String localName, String qName)
throws SAXException {
// TODO Auto-generated method stub
super.endElement(uri, localName, qName);
System.out.println("第"+i+",endElement结束"); } @Override
public void characters(char[] ch, int start, int length)
throws SAXException {
// TODO Auto-generated method stub
super.characters(ch, start, length);
//new String(ch, start, length)用来生成一个元素中标签之间的具体的文本
value = new String(ch, start, length);//加入正好解析到<name>冰与火之歌</name>时,那么value="冰与火之歌"
System.out.println("================节点值是:" + value);
if (!value.trim().equals("")) { System.out.println(i+"节点值是:" + value);
}
}
}
books.xml:
<?xml version="1.0" encoding="UTF-8"?>
<bookstore>
<book id="1">
<name>冰与火之歌</name>
<author>乔治马丁</author>
<year>2014</year>
<price>89</price>
</book>
<book id="2">
<name>安徒生童话</name>
<year>2004</year>
<price>77</price>
<language>English</language>
</book>
</bookstore>
解析结果下:
startDocument开始解析..............
第1处,解析到bookstore元素的标签。。。
================节点值是:
len:2
属性1:id
属性2:size
book.size:23
第1处,解析到book元素的标签。。。
================节点值是:
================节点值是:冰与火之歌
1节点值是:冰与火之歌
第1,endElement结束
================节点值是:
================节点值是:乔治马丁
1节点值是:乔治马丁
第1,endElement结束
================节点值是:
================节点值是:2014
1节点值是:2014
第1,endElement结束
================节点值是:
================节点值是:89
1节点值是:89
第1,endElement结束
================节点值是:
第1,endElement结束
================节点值是:
len:1
属性1:id
book.size:null
第2处,解析到book元素的标签。。。
================节点值是:
================节点值是:安徒生童话
2节点值是:安徒生童话
第2,endElement结束
================节点值是:
================节点值是:2004
2节点值是:2004
第2,endElement结束
================节点值是:
================节点值是:77
2节点值是:77
第2,endElement结束
================节点值是:
================节点值是:English
2节点值是:English
第2,endElement结束
================节点值是:
第2,endElement结束
================节点值是:
第2,endElement结束
endDocument结束解析............
sax解析的myHandler这个类继承了DefaultHandler,具体的解析逻辑就是写在这个myHandler
中,覆盖的方法的执行顺序是:
1. startDocument()
2.
startElement(String uri, String localName, String qName,
Attributes attributes)
3. endElement(String uri, String localName, String qName)
4. characters(char[] ch, int start, int length)
...
n. endDocument()
其中的...省略号部分一直重复的执行2,3,4两个步骤,主要是根据xml的具体情形,遇到一个具体元素就会执行2,3,4三个步骤一次。如上面的
xml中的
<name>冰与火之歌</name>
<author>乔治马丁</author>
<year>2014</year>
<price>89</price>
,这样就会重复执行2,3,4步骤四次。
SAX方式解析XML的更多相关文章
-
Android网络之数据解析----SAX方式解析XML数据
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/ ...
-
(四)SAX方式解析XML数据
SAX方式解析XML数据 文章来源:http://www.cnblogs.com/smyhvae/p/4044170.html 一.XML和Json数据的引入: 通常情况下,每个需要访问网络的应用程 ...
-
网络相关系列之四:数据解析之SAX方式解析XML数据
一.XML和Json数据的引入: 通常情况下.每一个须要訪问网络的应用程序都会有一个自己的server.我们能够向server提交数据,也能够从server获取数据.只是这个时候就有一个问题,这些数据 ...
-
Java&;Xml教程(五)使用SAX方式解析XML文件
Java SAX解析机制为我们提供了一系列的API来处理XML文件,SAX解析和DOM解析方式不太一样,它并不是將XML文件内容一次性全部加载,而是连续的部分加载. javax.xml.parsers ...
-
用JAXP的SAX方式解析XML文件
简单用JAXP的SAX方式(事件驱动)解析XML文件: 文件(1.XML) <?xml version="1.0" encoding="UTF-8" st ...
-
Java眼中的XML--文件读取--2 应用SAX方式解析XML
1.获取一个SAXParserFactory的实例.2.通过factory获取SAXParser实例. 3.新建一个包和继承自DefaultHandler的类. 因为SAX遍历方式,比如便利一个节 ...
-
SAX方式解析XML文件实例
books.XML文件: 书籍book.java实体类: public class Book { private String id; private String name; private Str ...
-
sax方式解析XML学习笔记
原理:对文档进行顺序扫描,当扫描到文档(document)开始与结束,元素开始与结束.文档结束等地方 通知事件处理函数,由事件处理函数相应动作然后继续同样的扫描,直至文档结束. 优点:消耗资源比较少: ...
-
使用SAX方式解析XML文件
package com.pingyijinren.test; import android.util.Log; import org.xml.sax.Attributes; import org.xm ...
随机推荐
-
Office 2016 正式发布——新特性预览
今天微软又发生了一件大事!Windows Office 2016正式发布,这标志着Windows Office 又达到了一个新的里程碑! 全新的Office 发布为Office 365 用户带来了新的 ...
-
【QCon笔记】Native 和 Web 融合
#main img{width:100%;} 简介 理清 Native 和 Web 的亮点和痛点,借鉴对方亮点解决自身的痛点,并给出淘系 App 在这些方面的实践. Mobile Web 的协作能力底 ...
-
几款web开发常用jquery特效代码
特效网:http://www.xwcms.net 1.图片拖动特效http://www.xwcms.net/js/tpdm/32946.html2.弹出层焦点图特效:http://www.xwcms ...
-
jdk安装与环境变量配置(一劳永逸)
换了一个项目组做新的项目,新的机器,又得重新打环境,懒得去百度下,这里做个备份,下回直接看就行,如下 进行java开发,首先要安装jdk,安装了jdk后还要进行环境变量配置: 1.下载jdk(http ...
-
(3)redis队列功能
Redis队列功能介绍 List 常用命令: Blpop删除,并获得该列表中的第一元素,或阻塞,直到有一个可用 Brpop删除,并获得该列表中的最后一个元素,或阻塞,直到有一个可用 Brpoplpus ...
-
VMWare虚拟机网络的三种工作模式
VMWare提供了三种工作模式: 1.bridged(桥接模式) 在这种模式下,VMWare虚拟出来的操作系统就像是局域网中的一*立的主机,它可以访问网内任何一台机器.在桥接模式下,需要手工为虚拟系 ...
-
Hibernate 主键策略
Hibernate主键生成策略 .自动增长identity 适用于MySQL.DB2.MS SQL Server,采用数据库生成的主键,用于为long.short.int类型生成唯一标识 使用SQL ...
-
解决Ubuntu14.04下Clementine音乐播放器不能播放wma文件的问题
参考:Ubuntu 14.04 安装深度音乐的方法 问题描述:播放wma文件时提示"GStreamer插件未安装". 解决方法:安装gstreamer-ffmpeg插件即可解决问题 ...
-
thinksns解析1
1.数据库 这儿是关于数据库的封装,还是挺厉害的,最终select中完成sql语句的封装,最后由query来完成底层api 2.初始化过程 sns也是通过框架完成显示调用,一开始通过i ...
-
spring使用jdbcTemplate和jdbcdaosupport和namedparameter
jdbcTemplate: 首先连接数据库 <!-- 导入外部文件 --> <context:property-placeholder location="classpat ...