本章只讲DOM解析。接下来还会学习Dom4j和StAX 解析技术

DOM解析:

DOM解析一次将所有的元素全部加载到内存中:如有以下XML文档:

    <user>
<name>Jack</name>
<age>30</age>
</user>

由于DOM解析,一次性的将所有元素(包含属性和文本) 全部加载到内存中,所以不适用于解析大量的数据。

JAXP-DOM解析:

包: 

javax.xml.parse – 关键类DocumentBuilder,文档解析对像。 

org.w3c.dom – 关键类Document代表内存中的文档对像模型。

java.xml – 关键类Transformer,用于将内存中的文档保存到文件中。

users.xml:-在xml4文件夹下面

<?xml version="1.0" encoding="UTF-8" standalone="no"?><users>
<user id="A001">
<name>Tom</name>
<age>23</age>
</user> <user id="C001">
<name>李四</name>
<age>33</age>
</user>
</users>
<!--添加进来了吧,为了演示而建立的简单xml文档-->

代码演示:

package cn.hncu.dom;

import java.io.File;
import java.io.IOException; import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult; import org.junit.Test;
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; /**
* @author 陈浩翔 2016-6-29
*/
public class DomDemo1 { @Test
// 需求:把第一个user节点的name的值取出来
public void getDom() throws SAXException, IOException,
ParserConfigurationException {
// 第一步,通过DocumentBuilderFactory类中的工厂方法等到一个dbf对象
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
// 第二步,通过dbf对象创建出一个DocumentBuilder对象
DocumentBuilder db = dbf.newDocumentBuilder();
// 第三步,通过db对象创建出一个Document对象
Document dom = db.parse("xml4/users.xml");
// db.parse( new File("xml4/users.xml") );//也可以 System.out.println(dom);// [#document: null] Node root = dom.getFirstChild();// 这个是根节点
System.out.println("root:" + root);// root:[users: null]
System.out.println(root.getNodeName());// users
System.out.println(root.getFirstChild().getNodeName());// #text
// 上面一句的输出是:#text ----dom中把空白符也看成是一个Node,这种情况对我们的解析通常会造成很大的麻烦
// ※※为解决上面的问题,我们以后解析时尽量不要用Node,而要用Element。
// 因为Element是元素它不包含属性和文字内容(包括空白符),因此可避开空白符的干扰 Element eRoot = (Element) root;
NodeList list = eRoot.getElementsByTagName("user");
System.out.println("user元素的数量:" + list.getLength()); System.out.println("第2个user元素" + list.item(1)); Node user1Node = list.item(0);
Element eUser1 = (Element) user1Node;// 要把Node强转成Element,因为Element是子接口,里面有getElementBy*等方法,而Node没有(只能采用childNodes的方式,这种方式会受空白符的干扰)
NodeList listNames = eUser1.getElementsByTagName("name");
String nm = listNames.item(0).getNodeName();// name--标签名
String nmVal = listNames.item(0).getTextContent();// 标签内部所包含的文本内容----相当于JavaScript中的innerText
System.out.println(nm + "," + nmVal);
} @Test //需求:把第二个user节点的age值取出来
public void getAge()throws Exception{
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
DocumentBuilder db = dbf.newDocumentBuilder();
Document dom = db.parse(new File("xml4/users.xml"));
Element root = (Element)dom.getFirstChild();
Element user2 = (Element)root.getElementsByTagName("user").item(1);
Element eAge = (Element)user2.getElementsByTagName("age").item(0);
String age = eAge.getTextContent();
System.out.println("age:"+age);
} //用java对xml文档进行CRUD---创建,遍历,更新,删除
//创建---需求:添加一个新的user
@Test
public void create() throws Exception{
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder db = factory.newDocumentBuilder();
Document dom = db.parse(new File("xml4/users.xml"));
Element root = (Element) dom.getFirstChild(); //创建一个新的user元素
Element eUserNode = dom.createElement("user");
eUserNode.setAttribute("id", "C001");//给元素添加属性
//创建name和age子元素
Element eName = dom.createElement("name");
eName.setTextContent("李四");//设置name标签容器中包含的文字
Element eAgeNode = dom.createElement("age");
eAgeNode.setTextContent("33");
//把所创建的元素组装成一颗子树,添加到整颗dom树上
eUserNode.appendChild(eName);
eUserNode.appendChild(eAgeNode);
root.appendChild(eUserNode); //再把当前内存中的dom对象存储进xml文件
TransformerFactory tf = TransformerFactory.newInstance();
Transformer trans = tf.newTransformer();
trans.transform(new DOMSource(dom), new StreamResult("xml4/users.xml")); } //遍历---查找
@Test
public void query() throws Exception{
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder db = factory.newDocumentBuilder();
Document dom = db.parse("xml4/users.xml");
Element root = (Element) dom.getFirstChild();//得到根节点 NodeList list = root.getElementsByTagName("user");//这个user是xml文档中的元素
for(int i=0;i<list.getLength();i++){//循环遍历
Element user = (Element) list.item(i);
String id = user.getAttribute("id");
String name = user.getElementsByTagName("name").item(0).getTextContent();
String age = user.getElementsByTagName("age").item(0).getTextContent();
System.out.println("id:"+id+",name:"+name+",age:"+age);
System.out.println("---------------------------------");
}
} //更新---要求:把最后一个user的年龄+10
@Test
public void update() throws Exception{//为了方便,就只抛这个异常了,如果是以后搞项目,一定要详细才行的
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); DocumentBuilder db = factory.newDocumentBuilder(); Document dom = db.parse( new File("xml4/users.xml") ); Element root = (Element) dom.getFirstChild(); NodeList list = root.getElementsByTagName("user"); Element eUser = (Element) list.item( list.getLength()-1 ); String sAge = eUser.getElementsByTagName("age").item(0).getTextContent(); int age = Integer.parseInt(sAge)+10;
System.out.println("age:"+eUser.getElementsByTagName("age").item(0).getTextContent());
eUser.getElementsByTagName("age").item(0).setTextContent(""+age);
System.out.println(eUser.getElementsByTagName("age").item(0).getTextContent()); //把内存中的当前dom对象存储到xml文件中
TransformerFactory tf = TransformerFactory.newInstance();
Transformer trans = tf.newTransformer();
trans.transform(new DOMSource(dom), new StreamResult("xml4/users.xml"));
//把xml源输出到目标---如果目标存在则是更新,否则就是创建 } //删除---需求:删除最后一个元素
@Test
public void delete() throws Exception{
// 第一步,通过DocumentBuilderFactory类中的工厂方法等到一个dbf对象
DocumentBuilderFactory foctory = DocumentBuilderFactory.newInstance();
// 第二步,通过dbf对象创建出一个DocumentBuilder对象
DocumentBuilder db =foctory.newDocumentBuilder();
// 第三步,通过db对象创建出一个Document对象
Document dom = db.parse("xml4/users.xml");
//获取根节点
Element root =(Element)dom.getFirstChild(); //获取将要删除的元素
NodeList list = root.getElementsByTagName("user");
Element e = (Element)list.item( list.getLength()-1 );
e.getParentNode().removeChild(e);
//在内存中已经移除了。 //把当前内存中的dom对象存储到xml文件中
TransformerFactory tf = TransformerFactory.newInstance();
Transformer trans = tf.newTransformer();
trans.transform(new DOMSource(dom), new StreamResult( "xml4/users.xml" ));
}
}

小知识点:

注意:子类才可以当父类用。

父类的话,如果你确定那个类一定是这个父类的某个子类了,才可以强转为子类!!!

Java---XML的解析(1)-DOM解析的更多相关文章

  1. XML解析之DOM解析技术案例

    Java代码: package com.xushouwei.xml; import java.io.File; import javax.xml.parsers.DocumentBuilder; im ...

  2. 2.1 使用JAXP 对 xml文档进行DOM解析

    //使用 jaxp 对xml文档进行dom解析 public class Demo2 { //必要步骤 @Test public void test() throws Exception { //1. ...

  3. 解析XML文件之使用DOM解析器

    在前面的文章中.介绍了使用SAX解析器对XML文件进行解析.SAX解析器的长处就是占用内存小.这篇文章主要介绍使用DOM解析器对XML文件进行解析. DOM解析器的长处可能是理解起来比較的直观,当然, ...

  4. xml的SAX解析和dom解析的区别

    一,区别 DOM解析 SAX解析 原理: 一次性加载xml文档,不适合大容量的文件读取 原理: 加载一点,读取一点,处理一点.适合大容量文件的读取 DOM解析可以任意进行增删改成 SAX解析只能读取 ...

  5. 使用JAXP对xml文档进行DOM解析基础

    XML解析方式分为两种:dom和sax         dom:(Document Object Model, 即文档对象模型) 是 W3C 组织推荐的处理 XML 的一种方式.       sax: ...

  6. xml解析之----DOM解析

    DOM模型(documentobject model) •DOM解析器在解析XML文档时,会把文档中的全部元素.依照其出现的层次关系.解析成一个个Node对象(节点). •在dom中.节点之间关系例如 ...

  7. Android笔记(四十五) Android中的数据存储——XML(一)DOM解析器

    DOM解析XML在j2ee开发中比较常见,在Dom解析的过程中,是先把dom全部文件读入到内存中,然后使用dom的api遍历所有数据,检索想要的数据,这种方式显然是一种比较消耗内存的方式,对于像手机这 ...

  8. XML文件解析之DOM解析

    XML文件是一种通用的数据交换格式,它的平台无关性,语言无关性,系统无关性,给数据集成与交互带来了极大的方便.基本的解析方式包括DOM解析和SAX解析,具体来说包括DOM解析,SAX解析,DOM4J解 ...

  9. android XML解析之DOM解析方式

    DOM 解析方式步骤: 第一步:首选需要获得DOM解析器工厂实例 DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance ...

随机推荐

  1. java web 文件上传下载

    文件上传下载案例: 首先是此案例工程的目录结构:

  2. easyui-helloworld

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  3. poj 2763: [JLOI2011]飞行路线(spfa分层图最短路)

    2763: [JLOI2011]飞行路线 Time Limit: 10 Sec Memory Limit: 128 MB Submit: 2156 Solved: 818 [Submit][Statu ...

  4. 【ADO.NET】3、从TXT中导入数据到数据库

    数据库字段与类型id int,Name nvarchar(20),Age int TXT文本内容为 小高-20张三-18李四-19 private void btnInput_Click(object ...

  5. clr介绍

    CLR(公用语言运行时)和Java虚拟机一样也是一个运行时环境,它负责资源管理(内存分配和垃圾收集),并保证应用和底层操作系统之间必要的分离..NET提供了一个运行时环境,叫做公用语言运行时(Comm ...

  6. WPF页面跳转

    WPF页面跳转有两种:一种是windows,另外一种是page  1:windows页面跳转windows 页面跳转相信学过winform编程的哥们都知道,先实例化该窗体然后show一下就可以了.eg ...

  7. Redis总录

    设计 选择合适的数据对象来存储对象:String,List,Hash(Entity角色对象),Set,Zset(需要排序): 选择存储是全局的,还是局部的: 机制 批处理(pipeline) 事务(w ...

  8. 一些Swift编程语言的相关资料

    苹果官方Swift文档<The Swift Programming Language> 苹果开发者Swift文档及介绍 中文版Apple官方Swift教程(Github协作翻译中) Git ...

  9. Hibernate Session 获取connection

    Hibernate Session 获取connection 由于最近一个项目要用到一条辅助的SQL ,hibernate里面的SQLQuery API 总的SQL语句不能包含 : 冒号, 固放弃Hi ...

  10. rabbitmq 测试

    --*-- import pika import datetime connection = pika.BlockingConnection(pika.ConnectionParameters( 'l ...