SAX解析XML

广告位

SAX(Simple API for XML)也是一种解析 XML 文件的方法,它虽然不是官方标准,但它是 X…

SAX(Simple API for XML)也是一种解析 XML 文件的方法,它虽然不是官方标准,但它是 XML 的事实标准,大部分 XML 解析器都支持它。

SAX 与 DOM 不同的是,它不是一次性将 XML 加载到内存中,而是从 XML 文件的开始位置进行解析,根据定义好的事件处理器,来决定当前解析的部分是否有必要存储。下面例子说明了 SAX 解析 XML 的过程。

【例 1】SAX 解析 XML 文件。将《DOM 解析 XML》中例 1 的 XML 文件作为源文件,编写解析类 JAXBSAXDemo.java,代码如下:

  package com.eshore;  import org.xml.sax.Attributes;  import org.xml.sax.SAXException;  import org.xml.sax.XMLReader;  import org.xml.sax.helpers.DefaultHandler;  import org.xml.sax.helpers.XMLReaderFactory;  public class JAXBSAXDemo extends DefaultHandler  {      private String preTag;      //接收文档开始的通知      @Override      public void startDocument() throws SAXException      {          preTag=null;      }      //接收元素开始的通知      @Override      public void startElement(String uri, String localName,String qName,Attributes attributes)throws SAXException      {          if("user".equals(qName))          {              System.out.println(qName+"节点的country属性值为:"+attributes.getValue("country"));          }          if("address".equals(qName))          {              System.out.println(qName+"节点的state属性值为:"+attributes.getValue("state"));          }          preTag=qName;      }        //接收元素结束的通知      @Override      public void endElement(String uri,String localName, String qName)throws SAXException      {          preTag=null;      }      //接收元素中数据的通知,在执行完startElement和endElement方法之后执行      public void characters(char ch[], int start, int length)throws SAXException      {          String value=new String(ch, start, length);          if("name".equals(preTag))          {              System.out.println("name节点的值为:"+value);          }          else if("english_name".equals(preTag))          {              System.out.println("english_name节点的值为:"+value);          }          else if("age".equals(preTag))          {              System.out.println("age节点的值为:"+value);          }          else if("sex".equals(preTag))          {              System.out.println("sex节点的值为:"+value);          }          else if("description".equals(preTag))          {              System.out.println("description节点的值为:"+value);          }          if("city".equals(preTag))          {              System.out.println("city节点的值为:"+value);          }          else if("area".equals(preTag))          {              System.out.println("area节点的值为:"+value);          }      }      public static void main(String[] args) throws Exception      {          //由XMLReaderFactory类 创建XMLReader实例          XMLReader xmlReader=XMLReaderFactory.createXMLReader();          //创建一事件监听类          JAXBSAXDemo handler=new JAXBSAXDemo();          //XMLReader解析类设定事件处理类          xmlReader.setContentHandler(handler);          //XMLReader解析类解析XML文件          xmlReader.parse("E:\users.xml");      }  }

上述代码中介绍了用 SAX 解析 XML 文件的步骤。通过上述代码可以看出,使用 SAX 解析 XML 时,需要以下几个步骤:

  • 用 XMLReaderFactory 类创建 XMLReader 实例:

XMLReader xml Reader=XMLReaderFactory. createXMLReader();

  • 创建一个事件监听类:

JAXBSAXDemo handler=new JAXBSAXDemo();

  • 为解析类设定事件处理类:

xmlReader.setContentHandler(handler);

  •  解析XML文件:

xmlReader. parse ("E:\users.xml");

提示:上述实例中应用的是 XMLReader 而不是 SAXParser,是因为在 SAX2 中实现解析的接口名称重命名为 XMLReader。在使用 SAX 解析 XML 资源文件时,默认使用 SAXParser 实现类,它继承自 AbstractSAXParser。同理,工厂类也是使用 XMLReaderFactory 而不只 ISASParserFactory 来创建解析类。

关于作者: 编程语言基础教程

为您推荐

广告位

发表评论