上次学习的是DOM解析见 天气预报Dom解析
这次我们来了解一下SAX是什么情况! 相对于DOM来说SAX在平时要用的多一下。
在上次DOM学习中,我们也看见了,解析DOM,循环用的很多。
那个XML简单,DOM树层次不深,说通俗点就像for循环一样嵌套
的不多。如果很深的话用SAX就要方便的多了.... 在写上次程序的时候,我是边看xml 边写代码,
需要看仔细些,我眼睛都看花了(可能是我变量名没定义好),另外定义那个变量时也不好弄 遍历时需要中间变量稍多些, 而且都是
差不多意思差不多的变量...... 我们直接来看一下实例:
books.xml
<?xml version="1.0" encoding="utf-8"?> <books count="3" xmlns="http://test.org/books"> <!--books's comment--> <book> <id>1</id> <name>Thinking in JAVA</name> </book> <book> <id>2</id> <name>Core JAVA2</name> </book> <book> <id>3</id> <name>C++ primer</name> </book> <book> <id>4</id> <name>数据结构(严蔚敏)</name> </book> </books>
关于接下来要上的实例 我简单说一下,这次需要解析的是上面xml文件。
我们需要把xml文件中所有书的信息摘取下来,最后统一输出。
①类 book.java 用于保存一本书的信息 这里为了简单,xml文件就只是简单写了个ID,name 当然还有价钱等其他信息....
public class Book { private int id; private String name; public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } }
②类XmlHandler.java 负责处理,管理xml保存书籍信息..
import java.util.ArrayList; import org.xml.sax.Attributes; import org.xml.sax.SAXException; import org.xml.sax.helpers.DefaultHandler; public class XmlHandler extends DefaultHandler { public ArrayList<Book> books ; private ArrayList<String> strList; private Book book; private StringBuilder sb = new StringBuilder(); @Override public void startDocument() throws SAXException { books = new ArrayList<Book>(); strList = new ArrayList<String>(); super.startDocument(); } @Override public void endDocument() throws SAXException { super.endDocument(); } @Override public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException { if(qName.equals("book")) { book = new Book(); } super.startElement(uri, localName, qName, attributes); } @Override public void endElement(String uri, String localName, String qName) throws SAXException { strList.add(qName); if(qName.equals("book")) { books.add(book); } else if(qName.equals("id")) { book.setId(Integer.parseInt(sb.toString().trim()) ); } else if(qName.equals("name")) { book.setName(sb.toString()); } super.endElement(uri, localName, qName); } @Override public void characters(char[] ch, int start, int length) throws SAXException { sb.setLength(0); String str = new String(ch,start,length); sb.append(str); super.characters(ch, start, length); } }
上面几个函数都是覆盖类DefaultHandler的函数 被覆盖的函数默认情况下,不执行任何操作。
在用SAX解析xml之前是需要用到几个关于SAX的几个函数:
SAXParserFactory factory = SAXParserFactory.newInstance();
SAXParser saxParser = factory.newSAXParser();
XMLReader xmlReader = saxParser.getXMLReader();
③ 下面是类XMLparse.java
import java.io.FileInputStream; import java.io.IOException; import javax.xml.parsers.ParserConfigurationException; import javax.xml.parsers.SAXParser; import javax.xml.parsers.SAXParserFactory; import org.xml.sax.InputSource; import org.xml.sax.SAXException; import org.xml.sax.XMLReader; public class XMLparse { /** * @param args * @throws SAXException * @throws ParserConfigurationException * @throws IOException */ public static void main(String[] args) throws ParserConfigurationException, SAXException, IOException { SAXParserFactory factory = SAXParserFactory.newInstance(); SAXParser saxParser = factory.newSAXParser(); XMLReader xmlReader = saxParser.getXMLReader(); XmlHandler xmlHandler = new XmlHandler(); xmlReader.setContentHandler(xmlHandler); FileInputStream is = new FileInputStream("D:\\books.xml"); InputSource inputSourse = new InputSource(is); xmlReader.parse(inputSourse); for(Book b:xmlHandler.books) { System.out.println("id: "+b.id); System.out.println("Name: "+b.name); } } }
SAX API是一个基于事件的API ,适用于处理数据流,即随着数据的流动而依次处理数据。
本次程序输出结果: