声明:类容为学习传智播客方立勋教学视频,总结。
一:
SAX采用事件处理方式解析XML文档:解析器和事件处理器(有多个处理器)
a:解析器可以使用JAXP的API创建,创建出SAX解析器后,就可以指定解析器去解析某个文档了。
b:解析器只要解析到xml文档的一个组成部分,就会调用时间处理器的一个方法,同时把当前解析到的内容作为方法的参数传递给事件处理器。
得到解析器是模版代码:
//1:创建解析工厂
SAXParserFactory factory = SAXParserFactory.newInstance();
//2:得到解析器
SAXParser sp = factory.newSAXParser();
//3:得到读取器
XMLReader reader = sp.getXMLReader();
//4设置处理器类容
//5读取xml类容
reader.parse("***");
我们的主要工作就是写事件处理器。
有两种方式:
a:实现ContentHandler接口
b:继承DefaultHandler类,覆盖我们需要的方法。
二:dom4j解析xml文档
二:dom4j解析xml文档
模版开始代码:
@Test
public void read() throws DocumentException{
SAXReader reader = new SAXReader();
Document doc = reader.read(new File("src/Book.xml"));
Element root = doc.getRootElement();
Element book = (Element) root.elements().get(1);
String value = book.element("书名").getText();
System.out.println(value);
}
写回文档的代码:
XMLWriter writer = new XMLWriter(new FileWriter("src/Book.xml"));
writer.write(doc);
writer.close();
dom4j有一个提取根标签的方法,很不错。
官方的说明文档很详细,基本一看就会了。就不在赘述了。
下面叙述一点XPath。w3cschool上面有这方面的讲解。但是讲解最好的个人认为是:
http://zvon.org/xxl/XPathTutorial/General_chi/examples.html