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