使用SAX和dom4j解析XML文档

声明:类容为学习传智播客方立勋教学视频,总结。

一:

    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文档
 模版开始代码:
	@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
 
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值