1.解析XML文件有三种解析方法:DOM SAX DOM4J。
2.首先SAX解析技术只能读取XML文档中的数据信息,不能对其文档中的数据进行添加,删除,修改操作;这就是SAX解析技术的一个缺陷。
3.SAX解析器中可以定义多个事件处理器对象。
SAX解析技术原理图:
//使用SAX技术解析XML文件的步骤?
public static void saxXml() throws Exception{
//第一步:调用SAXParserFactory.newInstance()方法得到创建SAX解析器的工厂
SAXParserFactory spf = SAXParserFactory.newInstance();
//第二步:调用解析器工厂对象SAXParserFactory的newSAXParser()方法得到SAX解析器对象
SAXParser sp = spf.newSAXParser();
//第三步:通过SAX解析器对象的parse()方法将被解析的XML文件和事件处理器相关联
//当把XML文件和某个具体的事件处理器关联之后,事件处理器中方法将会被SAX解析器自动调用,不用开发者手动调用。
sp.parse("src/myclass.xml", new MyDefaultHandler()); //这里的事件处理器对象按需求可以自己定义
}
}
//创建一个读取XML文件中所有内容的事件处理器对象
//需求:显示XML文档中所有元素的内容?
class MyDefaultHandler extends DefaultHandler{
@Override
public void startDocument() throws SAXException { //SAX解析器发现一个XML文档开始的功能
// TODO Auto-generated method stub
System.out.println("解析器发现XML文件。");
}
@Override
public void startElement(String uri, String localName, String qName,
Attributes attributes) throws SAXException { //SAX解析器发现一个XML文档中某个元素开始的功能
// TODO Auto-generated method stub
System.out.println("元素名称___"+qName); //读取元素名称
}
@Override
public void characters(char[] ch, int start, int length)
throws SAXException { //SAX解析器扫描XML文档中某个元素中文本的功能
// TODO Auto-generated method stub
String str = new String(ch,start,length); //将解析器扫描到的文本内容存储到str对象中
//为了显示内容的格式要求,去除文本后面的换行和空格
if(!str.trim().equals("")){
System.out.println(str); //显示XML文件中元素的文本内容
}
}
@Override
public void endElement(String uri, String localName, String qName)
throws SAXException { //SAX解析器发现一个XML文档中某个元素结束的功能
// TODO Auto-generated method stub
super.endElement(uri, localName, qName);
}
@Override
public void endDocument() throws SAXException { //SAX解析器发现一个XML文档结束的功能
// TODO Auto-generated method stub
System.out.println("该XML文件解析结束。");
}
}
//创建一个读取XML文件中部分元素文本内容的事件处理器
//需求:只显示XML文件中学生的名字和年龄元素内容?
class MyDefaultHandler1 extends DefaultHandler{
private boolean isName=false;
private boolean isAge=false;
//开始扫描一个XML文档
@Override
public void startDocument() throws SAXException {
// TODO Auto-generated method stub
System.out.println("开始扫描文档。");
}
//结束扫描一个XML文档
@Override
public void endDocument() throws SAXException {
// TODO Auto-generated method stub
System.out.println("文档扫描结束。");
}
//开始扫描一个XML文档中的元素
@Override
public void startElement(String uri, String localName, String qName,
Attributes attributes) throws SAXException {
// TODO Auto-generated method stub
if(qName.equals("name")){ //在开始扫描元素名称时,判断要显示的元素名称和文档中的元素名称
this.isName=true;
}else if(qName.equals("age")){
this.isAge=true;
}
}
//结束扫描一个XML文档中的元素
@Override
public void endElement(String uri, String localName, String qName)
throws SAXException {
// TODO Auto-generated method stub
super.endElement(uri, localName, qName);
}
//读取XML文档中部分元素的文本内容
@Override
public void characters(char[] ch, int start, int length)
throws SAXException {
// TODO Auto-generated method stub
String str = new String(ch,start,length);
if(!str.trim().equals("") && (isName || isAge)){
System.out.println(str);
}
isName=false;
isAge=false;
}
}