public class ParseXml extends DefaultHandler {
private String tagValue;
long starttime;
long endtime;
// 开始解析XML文件
public void startDocument() throws SAXException
{
//可以在此初始化变量等操作
System.out.println("~~~~解析文档开始~~~");
starttime=System.nanoTime();
}
// 结束解析XML文件
public void endDocument() throws SAXException
{
//endtime=System.currentTimeMillis();
endtime=System.nanoTime();
System.out.println("~~~~解析文档结束~~~");
//System.out.println("共用"+(endtime-starttime)+"毫秒");
System.out.println("共用"+(endtime-starttime)+"纳秒");
}
/**
* 在解释到一个开始元素时会调用此方法.但是当元素有重复时可以自己写算法来区分
*
*/
public void startElement(String uri, String localName, String qName,
Attributes attributes) throws SAXException
{
System.out.println("startElement处标签名:" + qName);
if (attributes != null && attributes.getLength() != 0)
{
// attributes.getQName(i):属性名称
// attributes.getValue(i):属性值
for (int i = 0;i < attributes.getLength();i++)
System.out.println(attributes.getQName(i) + " = " + attributes.getValue(i) + " ");
}
}
/**
* 在遇到结束标签时调用此方法
*/
public void endElement(String uri, String localName, String qName)
throws SAXException
{
System.out.print("endElement处的值是:");
System.out.println(tagValue);
}
/**
* 所有的XML文件中的字符会放到ch[]中
*/
public void characters(char ch[], int start, int length)
throws SAXException
{
tagValue = new String(ch,start,length).trim();
}
public static void main(String[] args) {
try {
SAXParserFactory sf = SAXParserFactory.newInstance();
SAXParser sp = sf.newSAXParser();
ParseXml px = new ParseXml();
sp.parse(new InputSource("struts.xml"), px);
System.out.println("======");
} catch (Exception e) {
e.printStackTrace();
}
}
XML文件里面不能包含
DTD头
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
不然就需要连外网,否则就会报
java.net.ConnectException: Connection timed out: connect
分享到:
相关推荐
SAX(Simple API for XML)解析是XML处理中的一种事件驱动模型,主要用于读取和解析XML文档。相较于DOM(Document Object Model)解析器,SAX解析器在内存使用上更为高效,因为它不需要一次性加载整个XML文档到内存...
在Java中,解析XML文件是常见的任务,通常有两种主要的解析方式:DOM(Document Object Model)和SAX(Simple API for XML)。本篇文章将详细探讨这两种解析方法,并通过实际例子来说明它们的使用。 DOM解析方式: ...
【Java - XML解析总结】 XML(eXtensible Markup Language)是一种用于标记数据的语言,广泛应用于数据交换、配置文件和Web服务。Java 提供了多种方法来解析 XML 文档,主要包括 DOM(Document Object Model)和 ...
本文将深入探讨如何在Kotlin中使用SAX解析XML字符串。 首先,让我们了解SAX解析的基本原理。SAX解析器在读取XML时会触发一系列事件,如开始文档、开始元素、字符数据、结束元素等。开发者需要定义一个实现`...
在"Dom4jExample.java"文件中,可能包含了使用DOM4J解析XML的基本步骤: - 加载XML文件:通过`SAXReader`类创建一个读取器实例。 - 解析XML:使用`read()`方法读取XML文档并生成Document对象。 - 遍历和修改XML:...
本节将详细介绍在Android中如何操作XML,特别是使用DOM和SAX两种解析器来解析XML文件。 首先,我们来看DOM(Document Object Model)解析方式。DOM解析器将整个XML文档加载到内存中,形成一个树形结构,使得开发者...
压缩包里面有两个文件:SAX.java和SAXparse.java 用来解析大于100M的xml文件,SAX读取xml不同于DOM方式,DOM方式在解析xml前需要全部加载xml文件,当xml文件很大时,就会出现内存不足的问题,而SAX则是逐行读取xml...
1.sax方式 代码如下: /** * 使用sax解析 */ public class SaxParse{ /** * sax解析器 */ private SAXParser parser; public SaxParse(){ try { SAXParserFactory f = SAXParserFactory.newInstance(); parser = f....
SAX包文件,可以直接进行xml的解析,需要导入包才可以使用,SAX(simple API for XML)是一种XML解析的替代方法。相比于DOM,SAX是一种速度更快,更有效的方法。它逐行扫描文档,一边扫描一边解析。而且相比于DOM,...
用SAXParse来XML解析,重点是ContentHandler的处理,可以很方便的对XML数据进行解析 用Gson解析json数据,要注意的是自定义的对象并不需要和接受的json数据的格式完全匹配,Gson只解析匹配的部分,所以自定义对象...