• sax解析操作XML


    ldom解析(dom4j解析)
    dom4j用法参考:http://blog.csdn.net/ful1021/article/details/45147821
    将整个XML使用类似树的结构保存在内存中,再对其进行操作。
    W3C组织推荐的处理XML的一种方式。
    需要等到XML完全加载进内存才可以进行操作
    耗费内存,当解析超大的XML时慎用。
    可以方便的对xml进行增删该查操作
    lsax解析:
    逐行扫描XML文档,当遇到标签时触发解析处理器,采用事件处理的方式解析xml
    (Simple API for XML)不是官方标准,但它是XML社区事实上的标准,几乎所有的XML解析器都支持它。
    在读取文档的同时即可对xml进行处理,不必等到文档加载结束,相对快捷
    不需要加载进内存,因此不存在占用内存的问题,可以解析超大XML
    只能用来读取XML中数据,无法进行增删改

    	public static void main(String[] args) throws Exception {
    		// 1.获取解析器工厂
    		SAXParserFactory factory = SAXParserFactory.newInstance();
    		// 2.通过工厂获取sax解析器
    		SAXParser parser = factory.newSAXParser();
    		// 3.获取读取器
    		XMLReader reader = parser.getXMLReader();
    		// 4.注册事件处理器
    		// reader.setContentHandler(new MyContentHandler());
    		reader.setContentHandler(new MyContentAdapter());
    		// 5.解析xml
    		reader.parse("book.xml");
    	}
    

    // 适配器设计模式 (父类空实现 接口中抽象方法,相对比MyContentHandler 类)
    class MyContentAdapter extends DefaultHandler {
    
    	private String eleName = null;
    	private int count = 0;
    
    	@Override
    	public void startElement(String uri, String localName, String name,
    			Attributes attributes) throws SAXException {
    		this.eleName = name;
    	}
    
    	@Override
    	public void characters(char[] ch, int start, int length)
    			throws SAXException {
    		if ("书名".equals(eleName) && ++count == 2) {
    			System.out.println(new String(ch, start, length));
    		}
    	}
    
    	@Override
    	public void endElement(String uri, String localName, String name)
    			throws SAXException {
    		eleName = null;
    	}
    }
    
    
    
    
    class MyContentHandler implements ContentHandler {
    	public void startDocument() throws SAXException {
    		System.out.println("文档解析开始了.......");
    	}
    
    	public void startElement(String uri, String localName, String name,
    			Attributes atts) throws SAXException {
    		System.out.println("发现了开始标签," + name);
    	}
    
    	public void characters(char[] ch, int start, int length)
    			throws SAXException {
    		System.out.println(new String(ch, start, length));
    	}
    
    	public void endElement(String uri, String localName, String name)
    			throws SAXException {
    		System.out.println("发现结束标签," + name);
    	}
    
    	public void endDocument() throws SAXException {
    		System.out.println("文档解析结束了.......");
    	}
    	
    	
    	
    	
    	
    	
    
    	public void endPrefixMapping(String prefix) throws SAXException {
    		// TODO Auto-generated method stub
    
    	}
    
    	public void ignorableWhitespace(char[] ch, int start, int length)
    			throws SAXException {
    		// TODO Auto-generated method stub
    
    	}
    
    	public void processingInstruction(String target, String data)
    			throws SAXException {
    		// TODO Auto-generated method stub
    
    	}
    
    	public void setDocumentLocator(Locator locator) {
    		// TODO Auto-generated method stub
    
    	}
    
    	public void skippedEntity(String name) throws SAXException {
    		// TODO Auto-generated method stub
    
    	}
    
    	public void startPrefixMapping(String prefix, String uri)
    			throws SAXException {
    		// TODO Auto-generated method stub
    
    	}
    
    }


    版权声明:本文为博主原创文章,未经博主允许不得转载。

  • 相关阅读:
    electron—Chromium有酒,Node有肉
    .NET 应用程序运行提示"!!0[] System.Array.Empty()找不到方法"的解决办法
    安装.Net Framework 4.6.2时出现“无法建立到信任根颁发机构的证书链”解决方法
    Electron入门
    npm使用淘宝镜像安装包
    MySQL Unable to convert MySQL date/time value to System.DateTime的解决办法
    axios无法在ie9,10,11环境下运行的问题解决
    解决ini-parser解析ini文件中文乱码问题
    git的tag,branch操作
    java类加载器
  • 原文地址:https://www.cnblogs.com/ful1021/p/4804319.html
Copyright © 2020-2023  润新知