• XML技术之SAX解析器


    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;
        }
    }

  • 相关阅读:
    dwz 嵌套网页的搜索刷新问题
    dwz 解决remote验证唯一时缓存问题。
    dwz div 局部刷新
    Oracle 递归查询子节点和父节点 函数方法
    关于未能加载文件或程序集“System.Web.Extensions, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35”或它的某一个依赖项的解决办法
    CentOS7搭建vsftp服务器
    Linux下 cmatrix的安装和使用(黑客屏保)
    配置动态web服务(wsgi)
    centos7 搭建discuz 全
    Centos7 更换为阿里源
  • 原文地址:https://www.cnblogs.com/1315925303zxz/p/5486435.html
Copyright © 2020-2023  润新知