XML技术之SAX解析器

1.解析XML文件有三种解析方法:DOM SAX DOM4J。

2.首先SAX解析技术只能读取XML文档中的数据信息,不能对其文档中的数据进行添加,删除,修改操作;这就是SAX解析技术的一个缺陷。

3.SAX解析器中可以定义多个事件处理器对象。

SAX解析技术原理图:

XML技术之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;
    }
}

上一篇:angular学习笔记(三十)-指令(7)-compile和link(1)


下一篇:angular学习笔记(三十)-指令(7)-compile和link(2)