一、SAX与DOM的区别
DOM:先将XML文件的内容全部读取
SAX:通过Handler类对文件的节点由外带内逐个解析,其中startElement表示解析开始便签,endElement表示解析结束标签。
二、SAX解析xml文件的步骤:
1. 通过SAXParserFactory的静态newInstance()方法获取SAXParserFactory实例factory
SAXParserFactory factory = SAXParserFactory.newInstance();
2. 通过SAXParserFactory实例的newSAXParser()方法返回SAXParser实例parser
SAXParser parser = factory.newSAXParser();
parser.parse("路径",handler类型对象);(需创建见3)
3. 创建一个类继承DefaultHandler,重写其中一些方法进行业务处理并创建这个类的实例handler创建一个package继承DefaultHandler
startElement():用于遍历xml的开始标签
endElement():遍历xml结束标签
startElement:解析开始
endElement:解析结束
总的来说,大体步骤如下:
SAX解析xml步骤
1.通过SAXParseFactory的静态newInstance()方法获取SAXParserFactory实例factory
2.通过SAXParserFactory实例的newSAXParser()方法返回SAXParser实例parser
3.创建一个类继承DefaultHandle,重写方发进行业务已处理创建这个类的实例handle
三、解析XML元素
1. 重写DefalutHandler的实现类对象的startElement()方法
2. 在startElement()方法中,先调用DefaultHanlder 的startElement()方法
3. 已知节点的属性名的情况下
if(qname.equals("book")){
String value = attributes.getValue("id");
}<br>
4.不知节点的属性名的情况下
获取属性长度
int length=attributes.getLength();
获取属性名和属性值
for(int i=0;i<length;i++){
System.out.print(attributes.getQname(index)+attributes.getValue(index));
}
四、SAX解析XML的速度比DOM的块,
SAX的解析XML的解析器,需要重写startElement()开始解析的方法and endElemaent()方法 结束解析的方法and characters()方法
重写charaters()方法时,String(byte[] bytes,int offset,int length)的构造方法进行数组的传递
再去除解析时多余空格
if(!value.trim().equals("")){
System.out.println(value);
}
使用 SAX 解析 XML 文件的节点名和节点间文本
startElement方法——String qName(第三个参数):节点名
startElement方法——Attributes attributes(第四个参数):节点名的属性操作
characters方法——char[] ch(第一个参数):xml整个文本内容,所以需截取想要的内容
五、SAXParserHandler类的执行顺序为:startDocument()开始Xml解析--->第一行,以后每行的执行顺序为——>startElement()---characters()--->endElemnet()---->到最后一行的<bookstore>---->endDcunment()。