xml—SAX解析

来源:互联网 发布:乐视视频mac客户端 编辑:程序博客网 时间:2024/05/16 12:16

.在使用DOM解析XML文档时,需要读取整个XML文档,在内存中构架代表整个DOM树的Document对象,

从而再对XML文档进行操作。此种情况,如果XML文档特别大,就会消耗计算机的大量内存,并且容易导致内存溢出。

 .SAX解析允许在读取文档时,即对文档进行处理,而不必等到整个文档装载完才会对文档进行操作。

 .SAX 采用事件处理的方式解析XML文件,涉及两个部分:解析器和事件处理器

  •   .解析器可以使用JAXP的API创建,创建出SAX解析器后,就可以指定解析器去解析某个XML文档
  •   .解析器采用SAX方式在解析某个XML文档时,它只要解析到XML文档的一个组成部分,都会去调用事件处理器的一个方法,解析器在调用事件处理器的方法时,会 把当前   解析到的XML文件内容作为方法的参数传递给时间处理器
  • 事件处理器有程序员编写,程序员通过事件处理器中方法的参数,就可以很轻松地得到SAX解析器解析到的数据,从而可以决定如何对数据进行处理
 

举例:book.xml

<?xml version="1.0" encoding="UTF-8" ?>

<书架>

    <书> 

        <书名 name = "xxxx ">java 就业培训教程</书名>

        <作者>张孝祥</作者>  

        <售价>109元</售价>

        <售价>39.00元</售价>

    </书>

    <书> 

        <书名 >JavaScript网页制作</书名>

        <作者>韩顺平</作者>  

        <售价>28.00元</售价>

    </书>

</书架>


//1.创建解析工厂

   SAXParserFactory factory = SAXParserFactory .newInstance();

//2.得到解释器

   SAXParser sp = factory.newSAXParser();

//3.得到读取器

   XMLReader reader = sp.getXMLReader();

//4.设置内容处理器

reader.setContentHandler(new ListHandler());

//5.读取xml文档内容

reader.parser("src/book.xml")

//得到xml文档中所有内容

class ListHandler implements ContentHandler(

   public void startElement(String url,String localName,String name,Attributes atts)

       throws SAXException(

       System.out.println("<"+name+">")

       //取属性

      for ( int  i=0; atts != null && i<atts.getLength();i++ )(

         String attName = atts.getQName(i);

         String  attValue = atts.getValue(i);

         System.out.println(attName  + "="+attValue );

    )

      

  )

  public void characters(char[] ch,int start,intlength)

              throws SAXException(   

             System.out.println(new String(ch,start,lengh));

        )

   public void endElement(String url,String localName,String name)

    throws SAXException(

         System.out.println("</"+name+">")

    )

)


// 获取指定标签的内容

//1.创建解析工厂

   SAXParserFactory factory = SAXParserFactory .newInstance();

//2.得到解释器

   SAXParser sp = factory.newSAXParser();

//3.得到读取器

   XMLReader reader = sp.getXMLReader();

//4.设置内容处理器

reader.setContentHandler(new TagValueHandler ());

//5.读取xml文档内容

reader.parser("src/book.xml")


class TagValueHandler extends DefaultHandler(

  private String currentTag;//记住当前解析的是什么标签

  private int needNumber =2;//记住想获取第几个作者标签的值

  private int currentNumber;//当前解析到的第几个作者标签 

   public void startElement(String url,String localName,String name,Attributes atts)

       throws SAXException(

          currentTag =name;

          if(currentTag .equals("作者"))(

             currentNumber++;

         )

    )

      

  )

  public void characters(char[] ch,int start,intlength)

              throws SAXException(   

                 if ("作者".equals(currentTag) && currentNumber ==needNumber  )(

                     System.out.println(new String(ch,start,length)) 

               )

        )

   public void endElement(String url,String localName,String name)

    throws SAXException(

            currentTag  = null;

    )

)

打印结果:韩顺平

0 0
原创粉丝点击