java中用dom解析xml的经典入门级文档

dom|xml

一、前言

用Java解析XML文档,最常用的有两种方法:使用基于事件的XML简单API(Simple API for XML)称为SAX和基于树和节点的文档对象模型(Document Object Module)称为DOM。Sun公司提供了Java API for XML Parsing(JAXP)接口来使用SAX和DOM,通过JAXP,我们可以使用任何与JAXP兼容的XML解析器。
JAXP接口包含了三个包:
(1)org.w3c.dom W3C推荐的用于XML标准规划文档对象模型的接口。
(2)org.xml.sax  用于对XML进行语法分析的事件驱动的XML简单API(SAX)
(3)javax.xml.parsers解析器工厂工具,程序员获得并配置特殊的特殊语法分析器。

二、前提

DOM编程不要其它的依赖包,因为JDK里自带的JDK里含有的上面提到的org.w3c.dom、org.xml.sax 和javax.xml.parsers包就可以满意条件了。

三、使用DOM解析XML文档

我们现在来看看DOM是如何解析XML的吧!同样的,我将从一个简单的不能再简单的例子来说明DOM是如何解析XML文档的,先让我们看看XML是什么内容吧:

<?xml version="1.0" encoding="gb2312"?>
<books>
<book email="zhoujunhui">
<name>rjzjh</name>
<price>jjjjjj</price>
</book>
</books>

简单的不能再简单了。但是该有的都有了,根元素、属性、子节点。好了,能反应问题就行了,下面来看看解析这个XML文件的Java代码吧!

1 public class DomParse {
2     public DomParse(){
3        DocumentBuilderFactory domfac=DocumentBuilderFactory.newInstance();
4        try {
5            DocumentBuilder dombuilder=domfac.newDocumentBuilder();
6            InputStream is=new FileInputStream("bin/library.xml");
7            Document doc=dombuilder.parse(is);
9            Element root=doc.getDocumentElement();
10          NodeList books=root.getChildNodes();
11          if(books!=null){
12              for(int i=0;i<books.getLength();i++){
13                  Node book=books.item(i);
14                  if(book.getNodeType()==Node.ELEMENT_NODE){
15                      String email=book.getAttributes().getNamedItem("email").getNodeValue();
16                      System.out.println(email);
17                      for(Node node=book.getFirstChild();node!=null;node=node.getNextSibling()){
18                          if(node.getNodeType()==Node.ELEMENT_NODE){
19                              if(node.getNodeName().equals("name")){
20                                  String name=node.getNodeValue();
21                                  String name1=node.getFirstChild().getNodeValue();
22                                  System.out.println(name);
23                                  System.out.println(name1);
24                              }
25                              if(node.getNodeName().equals("price")){
26                                  String price=node.getFirstChild().getNodeValue();
27             System.out.println(price);
28               }
29                          }
30                      }
31                  }
32              }
33        }
34    } catch (ParserConfigurationException e) {
35      e.printStackTrace();
36    } catch (FileNotFoundException e) {
37      e.printStackTrace();
38    } catch (SAXException e) {
39      e.printStackTrace();
40    } catch (IOException e) {
41      e.printStackTrace();
42        }
43    }
44    public static void main(String[] args) {
45        new DomParse();
46    }
47 }

四、代码解释

先看看这个程序引用类:
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;

//下面主要是org.xml.sax包的类
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;

上面那么简单的代码一看就明白了,但是为了介绍个DOM编程的大概还是来看看这个程序吧:

(1)得到DOM解析器的工厂实例

DocumentBuilderFactory domfac=DocumentBuilderFactory.newInstance();
得到javax.xml.parsers.DocumentBuilderFactory;类的实例就是我们要的解析器工厂

(2)从DOM工厂获得DOM解析器

DocumentBuilder dombuilder=domfac.newDocumentBuilder();
通过javax.xml.parsers.DocumentBuilderFactory实例的静态方法newDocumentBuilder()得到DOM解析器

(3)把要解析的XML文档转化为输入流,以便DOM解析器解析它

InputStream is=new FileInputStream("bin/library.xml");
InputStream是一个接口。

(4)解析XML文档的输入流,得到一个Document

Document doc=dombuilder.parse(is);
由XML文档的输入流得到一个org.w3c.dom.Document对象,以后的处理都是对Document对象进行的

(5)得到XML文档的根节点

Element root=doc.getDocumentElement();
在DOM中只有根节点是一个org.w3c.dom.Element对象。

(6)得到节点的子节点

NodeList books=root.getChildNodes();
for(int i=0;i<books.getLength();i++){
Node book=books.item(i);
}
这是用一个org.w3c.dom.NodeList接口来存放它所有子节点的,还有一种轮循子节点的方法,后面有介绍

(7)取得节点的属性值

String email=book.getAttributes().getNamedItem("email").getNodeValue();
System.out.println(email);
注意,节点的属性也是它的子节点。它的节点类型也是Node.ELEMENT_NODE

(8)轮循子节点

for(Node node=book.getFirstChild();node!=null;node=node.getNextSibling()){
    if(node.getNodeType()==Node.ELEMENT_NODE){
        if(node.getNodeName().equals("name")){
            String name=node.getNodeValue();
            String name1=node.getFirstChild().getNodeValue();
            System.out.println(name);
            System.out.println(name1);
        }
    if(node.getNodeName().equals("price")){
        String price=node.getFirstChild().getNodeValue();
        System.out.println(price);
    }
}

这段代码的打印输出为:
null
alterrjzjh
jjjjjj
从上面可以看出
String name=node.getNodeValue();  是一个空值。而
String name1=node.getFirstChild().getNodeValue(); 才是真正的值,这是因为DOM把<name> rjzjh</name>也当作是两层结构的节点,其父节点为<name>节点本身,且它只有一个子节点(如果有属性的话就不止 一个了!),子节点是它的值“rjzjh”,所以我们看到上面的结果。
还有,子节点的节点类型也是Node.ELEMENT_NODE型的,node.getNextSibling()方法是取下一个相邻的节点。

五、DOM结点

DOM是一些节点的集合,由于文档中可能包含有不同类型的信息,所以定义了几种不同类型的节点。DOM中最常见的节点类型有:

(1)元素:
元素是XML的基本构件。元素的子节点可以是其它元素、文本节点或两者都有。元素节点还可以只含有属性这一唯一类型的节点。

(2)属性:
属性节点包含关于元素节点的信息,但它不是元素的子节点

(3)文本:
文本节点文本信息,或干脆是空白的文本。

(4)文档:
文档节点是整个文档中所有其它节点的父节点
元素是一种很重要的类型节点,元素节点可以是其他节点的容器。

六、DOM解析XML文档的步骤:

主要几步见第四点的(1),(2),(3),(4)步骤

时间: 2016-05-08

java中用dom解析xml的经典入门级文档的相关文章

Android使用Dom解析xml文件并进行展示

本程序实现了使用Dom方法从网络端解析xml文件,展示在列表,并实现点击进入相关页面. 首先我们创建一个类,用来实现http请求和xml文件节点的获取,这里的http请求很简单,就传递一 个url,在代码中通过这样的一个方法实现 public String getXmlFromUrl(String url) { String xml = null; try { // defaultHttpClient DefaultHttpClient httpClient = new DefaultHttpC

XML 声明必须是文档中的第一个节点并且在它之前不允许出现空白字符

完整错误信息:         System.Xml.XmlException: 意外的 XML 声明.XML 声明必须是文档中的第一个节点并且在它之前不允许出现空白字符.第 64 行,位置 3. 背景:         拼接了两个xml文件,提示错误的位置一直第二个xml开头的位置 <?xmlversion="1.0" encoding="UTF-8"?>         第64行指的就是 <?xmlversion="1.0"

[Java开发之路](10)DOM解析XML文档

对象序列化的一个重要限制是它只是Java的解决方案:只有Java程序才能反序列化这种对象.一种更具操作性的解决方案是将数据转化为XML格式,这可以使其被各种各样的平台和语言使用. 1. 简介 DOM 是用与平台和语言无关的方式表示XML文档的官方 W3C 标准.DOM 是以层次结构组织的节点或信息片断的集合.这个层次结构允许开发人员在树中寻找特定信息.分析该结构通常需要加载整个文档和构造层次结构, 然后才能做任何工作. 由于它是基于信息层次的,因而 DOM 被认为是基于树或基于对象的.DOM 以

java 使用JDOM解析xml文件

java中如何使用JDOM解析xml文件呢?以下小编就用实例为大家详细的介绍一下.需要的朋友可以参考下   JDOM是一个开源项目,它基于树型结构,利用纯JAVA的技术对XML文档实现解析.生成.序列化以及多种操作.JDOM直接为JAVA编程服务.它利用更为强有力的JAVA语言的诸多特性(方法重载.集合概念以及映射),把SAX和DOM的功能有效地结合起来. JDOM的官方地址:http://www.jdom.org/1.首先新建一个接口和2个类,为后续做准备[Moveable.java] 复制代

java使用xpath解析xml示例分享_java

XPath即为XML路径语言(XML Path Language),它是一种用来确定XML文档中某部分位置的语言.XPath基于XML的树状结构,提供在数据结构树中找寻节点的能力.起初 XPath 的提出的初衷是将其作为一个通用的.介于XPointer与XSL间的语法模型.但是 XPath 很快的被开发者采用来当作小型查询语言. XPathTest.java 复制代码 代码如下: package com.hongyuan.test; import java.io.File;import java

阿里巴巴Java规约扫描-云效(对外)版使用文档

原理 集团编码规约扫描rdc版本,是基于阿里巴巴JAVA开发手册中需要遵守的规则,转化为实际自动化扫描的规约条目纳入rdc实验室检测范围,完成后将扫描报告上传,最后把解析结果数据展示给用户.目前对外,共包括51条规则的检测. 包括2种方式接入,2种方式对比:测试服务接入更简单,适应于只做单种测试类型的扫描:实验室接入稍复杂,适应于作多种测试类型集合.比如同时做单元测试和代码规约扫描,需要把包含2个阶段的.rdcci.yml放代码库根目录,云效-实验室文档参考. 云效-测试服务使用步骤 进入云效-

Python中有没有类似于JAVA的API那样的完整的查询文档

问题描述 大家好: 小弟目前在自学Python,以前有2年的JAVA开发经验.但是在自学的过程中,对于Python已提供哪些模块以及如何查看它们(包括源代码)很困惑.有达人来指点下吗? 顺便问下,Python怎么没有像JAVA那样的完整详细的API? 问题补充zwws 写道 解决方案 你在Windows里面安装完成后,有个Module Docs的连接.启动这个,然后选择open brower,就会出现一个本地服务器为你提供模块文档.如果和JavaDoc完全一样就是JavaDoc了,这是Pytho

[JAVA100例]068、使用DOM解析XML

import javax.xml.parsers.*; import org.w3c.dom.*; import java.io.*; public class DOMPageList { public static void main(String[] args) { try { //创建解析工厂 DocumentBuilderFactory dbfactory = DocumentBuilderFactory.newInstance(); //指定DocumentBuilder Docume

PHP中用SimpleXMLElement解析xml

<?php $content = <<<XML <?xml version="1.0" encoding="UTF-8"?> <test> <global_setting> <ping_protocol>HTTP</ping_protocol> <ping_port>80</ping_port> <ping_path>/index.html<