XML之SAX解析模型
DOM解析会把整个XML文件全部映射成Document里的树形结构,当遇到比较大的文件时,它的内存占用很大,查找很慢
SAX就是针对这种情况出现的解决方案,SAX解析器会从XML文件的起始位置起进行解析,同时根据已经定义好的事件处理器,来决定当前所解析的部分是否有必要进行记录并存储
import java.io.File; import javax.xml.parsers.SAXParser; import javax.xml.parsers.SAXParserFactory; public class SaxParser{ public static void main(){ File xmlFile = new File("E:\\article.xml"); SAXParserFactory factory = SAXParserFactory.newInstance(); try{ SAXParser parser = factory.newSAXParser(); parser.parse(xmlFile,newMySaxHandler()); }catch(Exception e){ e.printstacktrace(); } } } import org.xml.sax.Attributes; import org.xml.sax.SAXException; import org.xml.sax.helpers.DefaultHandler; public class MySaxHandler extends DefaultHandler{ static DateFormat formater = newSimpleDateFormat("yyyy-MM-dd"); private String content; //覆写DefaultHandler中的charaters方法,接收元素中字符数据的通知,在执行完startElement或endElement方法后都会执行此操作 @Override publicvoid charaters(char[] ch, int start, int length) throws SAXException{ content = newString(ch,start,length); } //当解析到元素的结束标签时触发 @Override publicvoid endElement(String uri,String localName, String qName) throws SAXException{ if("title".equals(qName)) System.out.println("标题:"+ content); else if("author".equals(qName)) System.out.println("作者:"+ content); else if("email".equals(qName)) System.out.println("电子邮件:"+ content); else if("date".equals(qName)) System.out.println("日期:"+ content); } //当解析到元素的开始标签时触发 @Override publicvoid startElement(String uri,String localName, String qName Attitudesattributes) throws SAXException{ if("article".equals(qName)){ System.out.println("所属分类:"+ attributes.getValue("category")); } } }DefaultHandler类
在解析XML数据时,要创建一个解析时的监听对象,一般可通过继承DefaultHandler类实现
void characters(char[] ch, int start, int length)
接收元素中字符数据的通知。
void endDocument()
接收文档结束的通知。
void endElement(String uri, String localName,String qName)
接收元素结束的通知。
void endPrefixMapping(String prefix)
接收名称空间映射结束的通知。
void error(SAXParseException e)
接收可恢复的解析器错误的通知。
void fatalError(SAXParseException e)
报告严重的 XML 解析错误。
void ignorableWhitespace(char[] ch, int start,int length)
接收元素内容中可忽略空白的通知。
void notationDecl(String name, StringpublicId, String systemId)
接收注释声明的通知。
void processingInstruction(String target,String data)
接收处理指令的通知。
InputSource resolveEntity(String publicId,String systemId)
解析外部实体。
void setDocumentLocator(Locator locator)
接收文档事件的 Locator 对象。
void skippedEntity(String name)
接收跳过的实体的通知。
void startDocument()
接收文档开始的通知。
void startElement(String uri, StringlocalName, String qName, Attributes attributes)
接收元素开始的通知。
uri - 名称空间 URI,如果元素没有任何名称空间URI,或者没有正在执行名称空间处理,则为空字符串。
localName - 本地名称(不带前缀),如果没有正在执行名称空间处理,则为空字符串。
qName - 限定的名称(带有前缀),如果限定的名称不可用,则为空字符串。
attributes - 附加到元素的属性。如果没有属性,则它将是空的 Attributes 对象。
void startPrefixMapping(String prefix, Stringuri)
接收名称空间映射开始的通知。
void unparsedEntityDecl(String name, StringpublicId, String systemId, String notationName)
接收未解析实体声明的通知。
void warning(SAXParseException e)
接收解析器警告的通知。
Attributes
int getIndex(String qName)
通过 XML 限定(前缀)名查找属性的索引。
int getIndex(String uri, String localName)
通过名称空间的名称查找属性的索引。
int getLength()
返回此列表中的属性个数。
String getLocalName(int index)
通过索引查找属性的本地名称。
String getQName(int index)
通过索引查找属性的 XML 限定(前缀)名。
String getType(int index)
通过索引查找属性的类型。
String getType(String qName)
通过 XML 限定(前缀)名查找属性的类型。
String getType(String uri, String localName)
根据名称空间的名称查找属性的类型。
String getURI(int index)
通过索引查找属性的名称空间 URI。
String getValue(int index)
通过索引查找属性的值。
String getValue(String qName)
通过 XML 限定(前缀)名查找属性的值。
String getValue(String uri, String localName)
根据名称空间的名称查找属性的值。
XML之SAX解析模型的更多相关文章
- xml的SAX解析和dom解析的区别
一,区别 DOM解析 SAX解析 原理: 一次性加载xml文档,不适合大容量的文件读取 原理: 加载一点,读取一点,处理一点.适合大容量文件的读取 DOM解析可以任意进行增删改成 SAX解析只能读取 ...
- xml的SAX解析规则
一,为什么要用它 1.1,讲解 DOM解析原理:一次性把xml文档加载进内存,然后在内存中构建Document树. 对内存要求比较要. 缺点: 不适合读取大容量的xml文件,容易导致内存溢出. SAX ...
- 【文件处理】xml 文件 SAX解析
SAX的全称是Simple APIs for XML,也即XML简单应用程序接口. 与DOM不同,SAX提供的访问模式是一种顺序模式,这是一种快速读写XML数据的方式. 当使用SAX分析器对XML文档 ...
- Android解析XML之SAX解析器
SAX(Simple API for XML)解析器是一种基于事件的解析器,它的核心是事件处理模式,主要是围绕着事件源以及事件处理器来工作的.当事件源产生事件后,调用事件处理器相应的处理方法,一个事件 ...
- xml——dom&sax解析、DTD&schema约束
dom解析实例: 优点:增删改查一些元素等东西方便 缺点:内存消耗太大,如果文档太大,可能会导致内存溢出 sax解析: 优点:内存压力小 缺点:增删改比较复杂 当我们运行的java程序需要的内存比较大 ...
- 使用jaxp对比xml进行SAX解析
package cn.itcast.sax; import java.io.IOException; import javax.xml.parsers.ParserConfigurationExcep ...
- XML之DOM解析模型
<?xml version= "1.0" encoding = "UTF-8"> <articles> <article cate ...
- JavaWeb学习笔记——XML和SAX解析区别
- XML.03-DOM和SAX解析
body,td { font-family: calibri; font-size: 10pt } XML.03-DOM和SAX解析 XML的DOM解析 解析 处理 回写 XML的SAX解析 SAX和 ...
随机推荐
- [HNOI2012]永无乡
题目描述 永无乡包含 n 座岛,编号从 1 到 n,每座岛都有自己的独一无二的重要度,按照重要度可 以将这 n 座岛排名,名次用 1 到 n 来表示.某些岛之间由巨大的桥连接,通过桥可以从一个岛 到达 ...
- 【luogu3384】【模板】树链剖分
省选被暴虐,成功爆0...顺便ditoly差点全省总分Rank1 orz..... 于是开始赶进度学新算法.... 然后决定开始学习树剖orz... 发现树剖很好用啊!!!! 然后做了模板题. 题目就 ...
- [UOJ UNR#1]奇怪的线段树
来自FallDream的博客,未经允许,请勿转载, 谢谢. 原题可以到UOJ看,传送门 如果存在一个点是白的,却有儿子是黑的,显然无解. 不然的话,只要所有黑色的“黑叶子”节点,即没有黑色的儿子的节点 ...
- 【vijos1943】上学路上
题目戳这里 描述 小雪与小可可吵架了,他们决定以后互相再也不理对方了.尤其是,他们希望以后上学的路上不会再相遇. 我们将他们所在城市的道路网视作无限大的正交网格图,每一个整数点 (x,y) 对应了一个 ...
- UDA机器学习基础—评估指标
这里举例说明 混淆矩阵 精确率 召回率 F1
- JavaScript实现简单的双向数据绑定
什么是双向数据绑定 双向数据绑定简单来说就是UI视图(View)与数据(Model)相互绑定在一起,当数据改变之后相应的UI视图也同步改变.反之,当UI视图改变之后相应的数据也同步改变. 双向数据绑定 ...
- 利用maven install jar到项目当中
接着上面利用maven打好的jar包.把刚刚打好的包放入其他项目当中怎么办? 只需要在相同的目录下执行mvn install,maven会自动把jar放到本地仓库中. 这样,原先maven项目中缺少依 ...
- TRIM ,LTRIM ,RTRIM ,空格过滤
- 628. Maximum Product of Three Numbers
Given an integer array, find three numbers whose product is maximum and output the maximum product. ...
- centos 7 破解密码
CentOS 7 root密码的重置方式和CentOS 6完全不一样,CentOS 7与之前的版本6变化还是比较大的,以进入单用户模式修改root密码为例. 1.重启开机按esc 2.按e ...