XML DOM 树形结构:

DOM 节点

根据 DOM,XML 文档中的每个成分都是一个节点

DOM 是这样规定的:

  • 整个文档是一个文档节点
  • 每个 XML 元素是一个元素节点
  • 包含在 XML 元素中的文本是文本节点
  • 每一个 XML 属性是一个属性节点
  • 注释是注释节点

常用节点类型

节点类型 NodeType Named Constant nodeName 的返回值 nodeValue 的返回值
Element 1 ELEMENT_NODE element name null
Attr 2 ATTRIBUTE_NODE 属性名称 属性值
Text 3 TEXT_NODE #text 节点名称

案例:

目标:解析xml文件后,Java程序能够得到xml文件的所有数据

思考:如何在解析之后保留xml的结构信息

xml文档:

实例:

package Test;
/**
* 案例:运用DOM解析xml文件,获得xml文件的所有数据
*/
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NamedNodeMap;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList; public class DOMDemo {
public static void main(String[] args) throws Exception {
/** 步骤一:创建一个DocumentBuilderFactory的对象
* 1.定义工厂 API,使应用程序能够从 XML 文档获取生成 DOM 对象树的解析器。
* 2. protected DocumentBuilderFactory()
* 用于阻止实例化的受保护构造方法
* 3. static DocumentBuilderFactory newInstance()
* 获取 DocumentBuilderFactory 的新实例。
*/
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance(); /** 步骤二:创建一个DocumentBuilder的对象
* 1.protected DocumentBuilder()
* 受保护的构造方法
* 2.使其从 XML 文档获取 DOM 文档实例。使用此类,应用程序员可以从 XML 获取一个 Document。
*/
DocumentBuilder db = dbf.newDocumentBuilder(); /** 步骤三:通过DocumentBuilder对象的parse方法加载book.xml文件到当前目录下
* 1.parse(File f)
* 将给定文件的内容解析为一个 XML 文档,并且返回一个新的 DOM Document 对象。
*/
Document document = db.parse("books.xml"); /** 步骤四:获取所有book节点的集合
* 1.getElementsByTagName():通过节点的名称来获取所有同名节点,
* 因为不只有一个节点,所以就把获取的所有节点都存放在一个节点集合中。
*/
NodeList booklist = document.getElementsByTagName("book");
System.out.println("一共有" + booklist.getLength() + "本书"); /** 步骤五:遍历每一个book节点
* 1.Node item(int index)
* 返回集合中的第 index 个项。
* 2.NamedNodeMap getAttributes()
* 包含此节点的属性的 NamedNodeMap(如果它是 Element);否则为 null。
*/ for(int i = 0; i < booklist.getLength(); i++){ // 前提:不知道book节点的id属性有多少
System.out.println("===========下面开始遍历第" + (i+1) + "本书的内容===========");
// 通过item方法获取一个book节点
Node book = booklist.item(i);
// 获取book节点的所有属性集合
NamedNodeMap attrs = book.getAttributes();
System.out.println("第" + (i+1) + "本书共有" + attrs.getLength() + "个属性");
// 遍历book的属性
for(int j = 0; j < attrs.getLength(); j++){
// 通过item方法获取book节点的某一个属性
Node attr = attrs.item(j);
// 获取属性名
System.out.print("属性名:" + attr.getNodeName());
// 获取属性值
System.out.println("--属性值:" + attr.getNodeValue());
} /* // 前提:已经知道book节点有且只有一个id属性
// 将book节点进行强制类型转换,转换成Element类型
Element ebook = (Element)booklist.item(i);
// 通过getAttribute("id")方法来获取属性值
String attrValue = ebook.getAttribute("id");
System.out.println("id属性值为:" + attrValue);
*/ /** 步骤六:解析book节点的子节点
* 1.NodeList getChildNodes()
* 包含此节点的所有子节点的 NodeList。
*/
NodeList childNodes = book.getChildNodes();
// 遍历childNodes获取每个节点的节点名和节点值
System.out.println("第" + (i+1) + "本书共有" + childNodes.getLength() + "个子节点");
for(int k = 0; k < childNodes.getLength(); k++){ /* 如果不对节点类型进行判断
* 遍历book节点的子节点后会发现有9个子节点,但是我们只写了4个子节点
* 输出了5个#text节点,这是Text类型的节点。
* 因为空格也属于子节点,所以也会i被遍历出来。
* */
// 区分出text类型的node以及element类型的node
if(childNodes.item(k).getNodeType() == Node.ELEMENT_NODE){
// 获取element类型节点的节点名
System.out.print("第" + (k+1) + "个节点的是" + childNodes.item(k).getNodeName() + ": "); /* 当我们用childNodes.item(k).getNodeValue()这种方法获取
* element类型的节点的节点值时会返回空,因为他认为
* <name>冰与火之歌</name>中“冰与火之歌”是<name>的子节点,
* 所以返回<name>节点的值当然是null,因为它认为“冰与火之歌”是节点而不是内容。
* 我们这时需要返回<name>节点的第一个子节点,再返回第一个子节点的值就可以了,
* 或者用getTextContent()也可以解决,它会获取所有子节点的节点值
* */
// System.out.println(childNodes.item(k).getFirstChild().getNodeValue());
System.out.println(childNodes.item(k).getTextContent());
} } } } }

运行结果:

一共有2本书
===========下面开始遍历第1本书的内容===========
第1本书共有1个属性
属性名:id--属性值:1
第1本书共有9个子节点
第2个节点的是name: 冰与火之歌
第4个节点的是author: 乔治马丁
第6个节点的是year: 2014
第8个节点的是price: 89
===========下面开始遍历第2本书的内容===========
第2本书共有1个属性
属性名:id--属性值:2
第2本书共有9个子节点
第2个节点的是name: 格林童话
第4个节点的是year: 2004
第6个节点的是price: 66
第8个节点的是language: English

Java-Web DOM方式解析xml文件的更多相关文章

  1. 用JAXP的dom方式解析XML文件

    用JAXP的dom方式解析XML文件,实现增删改查操作 dom方式解析XML原理 XML文件 <?xml version="1.0" encoding="UTF-8 ...

  2. 在iOS 开发中用GDataXML(DOM方式)解析xml文件

    因为GDataXML的内部实现是通过DOM方式解析的,而在iOS 开发中用DOM方式解析xml文件,这个时候我们需要开启DOM,因为ios 开发中是不会自动开启的,只有在mac 开发中才自动开启的.我 ...

  3. Java&Xml教程(二)使用DOM方式解析XML文件

    DOM XML 解析方式是最容易理解的,它將XML文件作为Document对象读取到内存中,然后你可以轻松地遍历不同的元素和节点对象.遍历元素和节点不需要按照顺序进行. DOM解析方式适合尺寸较小的X ...

  4. DOM方式解析XML文件实例

    books.XML文件: <?xml version="1.0" encoding="utf-8"?><bookstore>    &l ...

  5. dom方式解析xml文件的步骤

    使用java类即可

  6. 用DOM方式解析XML

    一.用DOM方式解析XML 此例子节点结构如下: 1.获取book节点属性 (1).如果不知道节点的属性,通过 NamedNodeMap attrs = book.getAttributes(); 来 ...

  7. Dom方式解析XML

    public class TestXML { public static void main(String[] args) throws SAXException, IOException { //D ...

  8. Java眼中的XML--文件读取--1 应用DOM方式解析XML

    初次邂逅XML: 需要解析的XML文件: 这里有两个book子节点. 1.如何进行XML文件解析前的准备工作,另外解析先获取book节点. 这个我后来看懂了: 这个Node的ELEMENT_NODE= ...

  9. Java&Xml教程(五)使用SAX方式解析XML文件

    Java SAX解析机制为我们提供了一系列的API来处理XML文件,SAX解析和DOM解析方式不太一样,它并不是將XML文件内容一次性全部加载,而是连续的部分加载. javax.xml.parsers ...

随机推荐

  1. 在outlook中查找Skype的聊天记录

    在outlook中和inbox平级,有一个Conversation History

  2. Python学习札记(二十二) 函数式编程3 filter & SyntaxError: unexpected EOF while parsing

    参考: filter Problem SyntaxError: unexpected EOF while parsing 遇到该语法错误,一般是由于 括号不匹配 问题. Note 1.filter 用 ...

  3. Prototype(原型)

    意图: 用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象. 适用性: 当要实例化的类是在运行时刻指定时,例如,通过动态装载:或者为了避免创建一个与产品类层次平行的工厂类层次时:或者当一个 ...

  4. OAF 返回供应商门户主页

    if (pageContext.getParameter("returnHomePage") != null) { pageContext.setForceForwardURL(& ...

  5. 1、lambda表达式

    lambda表达式中的类型是通过上下文推断出来的,类似String[] strArr = {"as","sd"};右边元素的子类型. 匿名内部类的情况:需要引用 ...

  6. 古董留念 - Microsoft Office 4.2中文版

    Office 4.2是Office 95的前一个版本,最适合运行在Windows 3.x上,但即使是最新的Windows 7 32位版也是可以安装它的(不信你可以试试)! 原版以软盘为载体,安装一次需 ...

  7. 201621123010《Java程序设计》第5周学习总结

    1. 本周学习总结 1.1 写出你认为本周学习中比较重要的知识点关键词 接口.面向接口编程 interface.implements has-a 关系 Comparable.Comparator 1. ...

  8. web 开发 css 默认值列表

    css默认值列表 HTML标签CSS属性默认值汇总 这个东西,在你需要还原默认值的时候,比较有用. 开始的时候 *{margin:0;padding:0;},当需要使用边距的时候,就需要还原HTML默 ...

  9. 移动端rem布局雪碧图解决方案 以及分享腾讯团队的在线雪碧图工具

    先分享一下地址:http://alloyteam.github.io/gopng/ 使用的方法也很简单,将需要的小图标拖进去,全部拖进去后再调位置(每拖一个进去都会帮你排列好,但是没有间隔,所以全部拖 ...

  10. 关于EPoll的个人理解

    1.epoll 是I/o多路复用的一种解决方案,对比select的优点有: a.支持打开最大的文件描述符(可高达百万) b.效率并不随着描述符的增多而线性下降.select每次是轮询,所以描述符越多效 ...