码迷,mamicode.com
首页 > 编程语言 > 详细

Java XML解析之DOM

时间:2015-06-17 00:18:30      阅读:162      评论:0      收藏:0      [点我收藏+]

标签:

DOM解析是官方提供的XML解析方式之一,使用时无需引入第三方包,代码编写简单,方便修改树结构,但是由于DOM解析时是将整个XML文件加载到内存中进行解析,因此当XML文件较大时,使用DOM解析效率会降低,而且可能造成内存溢出。
当XML文件较大时应采用SAX解析(下一篇中会介绍)。通常情况下,若XML文件只是用作系统的配置文件,文件一般不会很大,使用DOM解析基本就能解决问题。
 
以下分别是解析和生成xml的基本步骤:
 
1. XML解析:
上文已经说过DOM解析时是将整个XML文件加载到内存中,所以解析的第一步就是加载文件,需要用到以下代码:
1 DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
2 DocumentBuilder builder = factory.newDocumentBuilder();
3 Document document = builder.parse(in);// 参数有多种类型,在此例中选择的是InputStream类型的参数

这三行代码分别是创建解析器工厂,创建解析器,获取解析的XML文档树,之后就可以对document对象进行具体的操作。

其中的主要操作大概有以下几种:
1 Element root = document.getDocumentElement();// 获取文档的根节点
2 NodeList nodeList = document.getElementsByTagName("nodename");// 根据节点名称获取节点列表

然后再循环遍历nodeList中的节点,利用节点对象的getChildNodes()的方法获取子节点列表,直到取到所需要的节点。

解析注意点:
Dom解析会将xml中两个标签之间的所有内容都看成是子节点,包括空白,其中节点类型分为:
1. 带有标签的子节点看成Element类型的子节点
2. 不包含标签的空白子节点或者文字节点看成是text类型的子节点
获取节点值时,必须获取text类型的节点的值,而不是Element类型节点的值,Element节点的值永远都是null,也可以使用Element节点的getTextContent()来获取Element类型的节点值
所以,在遍历子节点时,需要做 nodeList.item(i).getNodeType() == Element.ELEMENT_NODE 这样的一次判断,若为true,则执行 nodeList.item(i).getTextContent() 来获取节点的值。
 
2. XML生成:
首先是创建一个Document对象,需要用到以下代码:
1 DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
2 DocumentBuilder builder = factory.newDocumentBuilder();
3 Document document = builder.newDocument();

然后是document对象的配置以及节点的创建和添加:

1 document.setXmlStandalone(true); //非必须配置,配置之后可以去除不必要的standalone属性
2 Element root = document.createElement("nodes"); // 创建文档根节点
3 document.appendChild(root);// 将根节点加入文档中

创建子节点,添加id属性,并加入根节点中,xml中节点的父子关系是通过节点的appendChild方法形成的。

1 Element node = document.createElement("node");// 创建子节点
2 node.setAttribute("id", "1"); // 为子节点添加属性
3 root.appendChild(node); // 将子节点加入到根节点中

当节点设置完成之后需要将document对象转换成xml文件,需要通过以下代码转换:

1 TransformerFactory factory = TransformerFactory.newInstance(); // 工厂类,用来获取转换对象
2 Transformer transformer = factory.newTransformer(); // 获取用于转换的对象
3 transformer.setOutputProperty(OutputKeys.INDENT, "yes"); // 设置文档自动换行
4 transformer.transform(new DOMSource(document), new StreamResult( new File("E:\\nodes.xml")));// 实现转换,需要将转换的源对象与目标文件包装一下
至此,通过DOM完成了XML文件的生成。
 
DOM解析与创建XML的基本步骤也就是以上这么多,这是我学习之后的总结,希望对需要学习这方面知识的朋友能有些许帮助。

Java XML解析之DOM

标签:

原文地址:http://www.cnblogs.com/java-linux/p/4582036.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!