加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

sax解析操作XML

发布时间:2020-12-16 09:11:34 所属栏目:百科 来源:网络整理
导读:l dom 解析(dom4j解析) : dom4j用法参考: http://blog.csdn.net/ful1021/article/details/45147821 ? 将整个 XML 使用类似树的结构保存在内存中,再对其进行操作。 ? 是 W3C 组织推荐的处理 XML 的一种方式。 ? 需要等到 XML 完全加载进内存才可以进行操作
l dom 解析(dom4j解析)
dom4j用法参考:http://blog.csdn.net/ful1021/article/details/45147821
? 将整个 XML 使用类似树的结构保存在内存中,再对其进行操作。
? W3C 组织推荐的处理 XML 的一种方式。
? 需要等到 XML 完全加载进内存才可以进行操作
? 耗费内存,当解析超大的 XML 时慎用。
? 可以方便的对 xml 进行增删该查操作
l sax 解析:
? 逐行扫描 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 name)
			throws SAXException {
		eleName = null;
	}
}




class MyContentHandler implements ContentHandler {
	public void startDocument() throws SAXException {
		System.out.println("文档解析开始了.......");
	}

	public void startElement(String uri,Attributes atts) throws SAXException {
		System.out.println("发现了开始标签," + name);
	}

	public void characters(char[] ch,int length)
			throws SAXException {
		System.out.println(new String(ch,length));
	}

	public void endElement(String uri,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 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

	}

}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读