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 } } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |