sax方式解析xml文档
1. SAX采用事件处理的方式解析XML文件,利用 SAX 解析 XML 文档,
涉及两个部分:解析器和事件处理器:
解析器可以使用JAXP的API创建,创建出SAX解析器后,
就可以指定解析器去解析某个XML文档。
解析器采用SAX方式在解析某个XML文档时,它只要解析到XML文档的一个组成部分,
都会去调用事件处理器的一个方法,解析器在调用事件处理器的方法时,
会把当前解析到的xml文件内容作为方法的参数传递给事件处理器。
事件处理器由程序员编写,程序员通过事件处理器中方法的参数,
就可以很轻松地得到sax解析器解析到的数据,从而可以决定如何对数据进行处理。
2.解析步骤:
使用SAXParserFactory创建SAX解析工厂
SAXParserFactory spf = SAXParserFactory.newInstance();
通过SAX解析工厂得到解析器对象
SAXParser sp = spf.newSAXParser();
通过解析器对象得到一个XML的读取器
XMLReader xmlReader = sp.getXMLReader();
设置读取器的事件处理器
xmlReader.setContentHandler(new NameHandler());
解析xml文件
xmlReader.parse("book.xml");
其中NameHandler需要自己编写。通常处理器,都从DefaultHandler继承
class NameHandler extends DefaultHandler{
private String currentNode = null;
private int index = 1; //记住想获取第几个作者的值
private int count = 0; //记住当前解析到的是第几个作者
public void startElement(String uri, String localName, String name,
Attributes atts) throws SAXException {
if(name.equals("作者")){
currentNode = "作者";
count++;
}
}
public void characters(char[] ch, int start, int length)
throws SAXException {
if(currentNode!=null && currentNode.equals("作者") && count==index){
String content = new String(ch,start,length);
System.out.println(content);
}
}
public void endElement(String uri, String localName, String name)
throws SAXException {
currentNode = null;
}