package com.jelly.xml;
import java.io.File;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
import org.xml.sax.SAXException;
/**
* SAX解析XML
* @author Jelly
* QQ:136179492
*
*/
public class SaxTest {
/**
* @param args
* @throws SAXException
* @throws Exception
*/
public static void main(String[] args) throws Exception{
//step 1:获得SAX解析工厂实例
SAXParserFactory factory = SAXParserFactory.newInstance();
//step 2:获得SAX解析实例
SAXParser saxParser = factory.newSAXParser();
//step 3:开始解析
saxParser.parse(new File("Test.xml"), new SaxTest2());
}
}
package com.jelly.xml;
import java.util.Stack;
import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;
/**
* SAX解析XML Handler类
* @author Jelly
*
*/
public class SaxTest2 extends DefaultHandler{
public Stack<String> stack = new Stack<String>();
private String name;
private String address;
public void startElement(String uri, String localName, String qName,
Attributes attributes) throws SAXException {
stack.push(qName);
for (int i = 0; i <attributes.getLength(); i++) {
String name = attributes.getQName(i);
String value = attributes.getValue(i);
System.out.println(name+"===="+value);
}
}
public void endElement(String uri, String localName, String qName)
throws SAXException {
stack.pop();
if("person".equals(qName)){
System.out.println("姓名:"+this.name);
System.out.println("地址:"+this.address);
}
}
public void characters(char[] ch, int start, int length)
throws SAXException {
String tag = stack.peek();
if(tag.equals("name")){
name = new String(ch,start,length);
this.name = name;
}
if(tag.equals("address")){
this.address = new String(ch,start,length);
}
}
}
<?xml version="1.0" encoding="UTF-8"?>
<people>
<person personId="s01">
<name>jelly</name>
<address>wufsfsfsfssf</address>
</person>
<person personId="s02">
<name>jelly2</name>
<address>chengdu</address>
</person>
</people>
Dom:
DOM 是处理 XML 数据的传统方法。使用 DOM 时,数据以树状结构的形式被加载到内存中。DOM 以及广义的基于树的处理具有几个优点。首先,由于树在内存中是持久的,因此可以修改它以便应用程序能对数据和结构作出更改。它还可以在任何时候在树中上下导航,而不是像 SAX 那样是一次性的处理。DOM 使用起来也要简单得多。
另一方面,在内存中构造这样的树涉及大量的开销。大型文件完全占用系统内存容量的情况并不鲜见。此外,创建一棵 DOM 树可能是一个缓慢的过程。
SAX:
SAX 处理涉及以下步骤:
1.创建一个事件处理程序。
2.创建 SAX 解析器。
3.向解析器分配事件处理程序。
4.解析文档,同时向事件处理程序发送每个事件。
这种处理的优点非常类似于流媒体的优点。分析能够立即开始,而不是等待所有的数据被处理。而且,由于应用程序只是在读取数据时检查数据,因此不需要将数据存储在内存中。这对于大型文档来说是个巨大的优点。事实上,应用程序甚至不必解析整个文档;它可以在某个条件得到满足时停止解析。一般来说,SAX 还比它的替代者 DOM 快许多。
另一方面,由于应用程序没有以任何方式存储数据,使用 SAX 来更改数据或在数据流中往后移是不可能的。
选择 DOM 还是选择 SAX,这取决于下面几个因素:
1.应用程序的目的:如果打算对数据作出更改并将它输出为 XML,那么在大多数情况下,DOM 是适当的选择。并不是说使用 SAX 就不能更改数据,但是该过程要复杂得多,因为您必须对数据的一份拷贝而不是对数据本身作出更改。
2.数据容量: 对于大型文件,SAX 是更好的选择。
数据将如何使用:如果只有数据中的少量部分会被使用,那么使用 SAX 来将该部分数据提取到应用程序中可能更好。 另一方面,如果您知道自己以后会回头引用已处理过的大量信息,那么 SAX 也许不是恰当的选择。
3.对速度的需要: SAX 实现通常要比 DOM 实现更快。
SAX 和 DOM 不是相互排斥的,记住这点很重要。您可以使用 DOM 来创建 SAX 事件流,也可以使用 SAX 来创建 DOM 树。事实上,用于创建 DOM 树的大多数解析器实际上都使用 SAX 来完成这个任务!
分享到:
相关推荐
SAX解析XML文件的实例。一个项目同时用dom解析和sax解析xml文件貌似会报错,项目框架建一直是用sax和dom4j解析xml文件的。当我用dom解析xml文件。导入包后就报错识别不了xml文件的编码格式。于是做了一个sax解析xml...
Sax解析XML文件解
Java SAX解析Xml Demo(详细注释)
Servlet利用SAX解析XML文档,JAX,JSWDP,Servlet利用SAX解析XML文档
Sax解析xml文件详细例子,解析复杂节点的xml,把内容显示到view中,例子简单完整,易用
Servlet利用SAX解析XML文档(新上传的有源码)Servlet利用SAX解析XML文档(新上传的有源码)Servlet利用SAX解析XML文档(新上传的有源码)Servlet利用SAX解析XML文档(新上传的有源码)Servlet利用SAX解析XML文档(新上传的有...
下面是一个SAX解析XML的示例(有点长,因为详细注解了SAX事件处理的所有方法),SAX API中主要有四种处理事件的接口,它们分别是ContentHandler,DTDHandler, EntityResolver 和 ErrorHandler 。下面的例子可能...
使用sax解析xml的源代码
java学习笔记——使用DOM解析XML和使用SAX解析XML
sax解析XML方式的代码及特点,sax解析XML方式的代码及特点,sax解析XML方式的代码及特点,sax解析XML方式的代码及特点
NULL 博文链接:https://wang-peng1.iteye.com/blog/1133695
绝对可用的SAX解析XML文件项目,费了九牛二虎之力,才找到的好资源,特与大家共享出来。直接导入eclipse就可运行,无需任何配置。
Android SAX 解析XML SAX 解析XML(通用)
DOM和SAX解析XML文档
JAVA SAX解析XMLJAVA SAX解析XMLJAVA SAX解析XML
sax解析xml本地读取xml,希望对你有用
SAX解析XML源码:安卓客户端程序,通过HTTP协议从服务器端获取XML文件,然后解析并输出到控制台
使用sax解析xml,有详细的解析及源代码实例
NULL 博文链接:https://mazhihui.iteye.com/blog/1535280
Sax解析xml中的某个(一部分报文节点)循环组的内容