JAXP操作xml

转载自   JAXP操作xml

DOM对象详解
1.基本的DOM对象

DOM的基本对象有5个:Document,Node,NodeList,Element和Attr。下面就这些对象的功能和实现的方法作一个大致的介绍。

Document 对象代表了整个XML的文档,所有其它的Node,都以一定的顺序包含在Document对象之内,排列成一个树形的结构,程序员可以通过遍历这颗树来得 到XML文档的所有的内容,这也是对XML文档操作的起点。我们总是先通过解析XML源文件而得到一个Document对象,然后再来执行后续的操作。此 外,Document还包含了创建其它节点的方法,比如createAttribut()用来创建一个Attr对象。它所包含的主要的方法有:

createAttribute(String):用给定的属性名创建一个Attr对象,并可在其后使用setAttributeNode方法来放置在某一个Element对象上面。

createElement(String):用给定的标签名创建一个Element对象,代表XML文档中的一个标签,然后就可以在这个Element对象上添加属性或进行其它的操作。

createTextNode(String):用给定的字符串创建一个Text对象,Text对象代表了标签或者属性中所包含的纯文本字符串。如果在一个标签内没有其它的标签,那么标签内的文本所代表的Text对象是这个Element对象的唯一子对象。

getElementsByTagName(String):返回一个NodeList对象,它包含了所有给定标签名字的标签。

getDocumentElement():返回一个代表这个DOM树的根节点的Element对象,也就是代表XML文档根元素的那个对象。

Node 对象是DOM结构中最为基本的对象,代表了文档树中的一个抽象的节点。在实际使用的时候,很少会真正的用到Node这个对象,而是用到诸如 Element、Attr、Text等Node对象的子对象来操作文档。Node对象为这些对象提供了一个抽象的、公共的根。虽然在Node对象中定义了 对其子节点进行存取的方法,但是有一些Node子对象,比如Text对象,它并不存在子节点,这一点是要注意的。Node对象所包含的主要的方法有:

appendChild(org.w3c.dom.Node):为这个节点添加一个子节点,并放在所有子节点的最后,如果这个子节点已经存在,则先把它删掉再添加进去。

getFirstChild():如果节点存在子节点,则返回第一个子节点,对等的,还有getLastChild()方法返回最后一个子节点。

getNextSibling():返回在DOM树中这个节点的下一个兄弟节点,对等的,还有getPreviousSibling()方法返回其前一个兄弟节点。

getNodeName():根据节点的类型返回节点的名称。

getNodeType():返回节点的类型。

getNodeValue():返回节点的值。

hasChildNodes():判断是不是存在有子节点。

hasAttributes():判断这个节点是否存在有属性。

getOwnerDocument():返回节点所处的Document对象。

insertBefore(org.w3c.dom.Node new,org.w3c.dom.Node ref):在给定的一个子对象前再插入一个子对象。

removeChild(org.w3c.dom.Node):删除给定的子节点对象。

replaceChild(org.w3c.dom.Node new,org.w3c.dom.Node old):用一个新的Node对象代替给定的子节点对象。

NodeList对象,顾名思义,就是代表了一个包含了一个或者多个Node的列表。可以简单的把它看成一个Node的数组,我们可以通过方法来获得列表中的元素:

GetLength():返回列表的长度。

Item(int):返回指定位置的Node对象。

Element对象代表的是XML文档中的标签元素,继承于Node,亦是Node的最主要的子对象。在标签中可以包含有属性,因而Element对象中有存取其属性的方法,而任何Node中定义的方法,也可以用在Element对象上面。

getElementsByTagName(String):返回一个NodeList对象,它包含了在这个标签中其下的子孙节点中具有给定标签名字的标签。

getTagName():返回一个代表这个标签名字的字符串。

getAttribute(String): 返回标签中给定属性名称的属性的值。在这儿需要主要的是,应为XML文档中允许有实体属性出现,而这个方法对这些实体属性并不适用。这时候需要用到 getAttributeNodes()方法来得到一个Attr对象来进行进一步的操作。

getAttributeNode(String):返回一个代表给定属性名称的Attr对象。

Attr 对象代表了某个标签中的属性。Attr继承于Node,但是因为Attr实际上是包含在Element中的,它并不能被看作是Element的子对象,因 而在DOM中Attr并不是DOM树的一部分,所以Node中的getparentNode(),getdivviousSibling()和 getnextSibling()返回的都将是null。也就是说,Attr其实是被看作包含它的Element对象的一部分,它并不作为DOM树中单独 的一个节点出现。这一点在使用的时候要同其它的Node子对象相区别。

需要说明的是,上面所说的DOM对象在DOM中都是用接口定义的, DOM其实可以在任何面向对象的语言中实现,只要它实现了DOM所定义的接口和功能就可以了。

2,关于JAXP

  JAXP 开发包是J2SE的一部分,它由javax.xml、org.w3c.dom 、org.xml.sax 包及其子包组成

  在 javax.xml.parsers 包中,定义了几个工厂类,程序员调用这些工厂类,可以得到对xml文档进行解析的 DOM 或 SAX 的解析器对象。

使用JAXP进行DOM解析

javax.xml.parsers包中的DocumentBuilderFactory用于创建DOM模式的解析器对象 , DocumentBuilderFactory是一个抽象工厂类,它不能直接实例化,但该类提供了一个newInstance方法 ,这个方法会根据本地平台默认安装的解析器,自动创建一个工厂的对象并返回。

获得JAXP中的DOM解析器

调用 DocumentBuilderFactory.newInstance() 方法得到创建 DOM 解析器的工厂。

调用工厂对象的 newDocumentBuilder方法得到 DOM 解析器对象。

调用 DOM 解析器对象的 parse()方法解析 XML 文档,得到代表整个文档的 Document 对象,进行可以利用DOM特性对整个XML文档进行操作了。

更新XML文档

 

javax.xml.transform包中的Transformer类用于把代表XML文件的Document对象转换为某种格式后进行输出,例如把xml文件应用样式表后转成一个html文档。利用这个对象,当然也可以把Document对象又重新写入到一个XML文件中。

Transformer类通过transform方法完成转换操作,该方法接收一个源和一个目的地。我们可以通过:

•        javax.xml.transform.dom.DOMSource类来关联要转换的document对象,

•        用javax.xml.transform.stream.StreamResult 对象来表示数据的目的地。

 Transformer对象通过TransformerFactory获得。

看一个简单示例:

Book.xml

<?xmlversion="1.0"encoding="UTF-8"standalone="no"?>
<book>
<bookname>Java程序设计</bookname>
<bookprice>40元</bookprice>
<author>lijizh</author>
<publisher>lijizh1013</publisher>
</book>

Dom.java

package dtd;import java.io.IOException;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
importjavax.xml.parsers.ParserConfigurationException;import org.w3c.dom.Document;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;publicclass Dom {publicstaticvoid main(String[] args) throws ParserConfigurationException,SAXException, IOException {//获取解析工厂DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();//创建解析器对象DocumentBuilder db = dbf.newDocumentBuilder();//获取Document对象Document d = db.parse("src/dtd/Book.xml");//通过Document对象的方法获取相应的节点列表NodeList nl = d.getElementsByTagName("bookname");//获取指定节点Node node = nl.item(0);//获取指定节点内容String content = node.getTextContent();//输出内容System.out.println(content);}
}

示例完成对XML文件的CRUD操作:

Book.xml

<?xmlversion="1.0"encoding="UTF-8"standalone="no"?>
<book>
<bookname>Java程序设计</bookname>
<bookprice>40元</bookprice>
<author>lijizh</author>
<publisher>lijizh1013</publisher>
</book>

ReadDom.java

package dtd;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.TransformerConfigurationException;
import javax.xml.transform.TransformerException;
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;publicclass ReadDom {@Testpublicvoid read() throws ParserConfigurationException, SAXException, IOException{DocumentBuilderFactoryfactory = DocumentBuilderFactory.newInstance();DocumentBuilder db =factory.newDocumentBuilder();Document d = db.parse("src/dtd/Book.xml");Node node = d.getElementsByTagName("book").item(0);//  System.out.println(node.getNodeName());list(node);      }//用此方法遍历元素节点
private void list(Node node) {if(node instanceof Element){System.out.println(node.getNodeName());}NodeList list = node.getChildNodes();for(int i = 0;i< list.getLength();i++){Node node1 =list.item(i);list(node1);}}@Test//以尾部追加的方式向XML文件中增添数据的方法public void insert() throws ParserConfigurationException, SAXException,IOException, TransformerException{DocumentBuilderFactory factory =DocumentBuilderFactory.newInstance();DocumentBuilderdb = factory.newDocumentBuilder();Document d = db.parse("src/dtd/Book.xml"); Element node = (Element)d.getElementsByTagName("book").item(0);Element newNode =d.createElement("color");newNode.setTextContent("red");node.appendChild(newNode);//通过转换工厂的newInstance()方法获取工厂实例TransformerFactory tff =TransformerFactory.newInstance();//获取转换器Transformer tf =tff.newTransformer();//通过转换器对象的transform方法将源与目标文件相连接tf.transform(new DOMSource(d),new StreamResult("src/dtd/Book.xml"));
}@Test//以向前插入的方式向XML文件中增添数据的方法publicvoid insert1() throws ParserConfigurationException, SAXException, IOException,TransformerException{DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();DocumentBuilder db = factory.newDocumentBuilder();Document d = db.parse("src/dtd/Book.xml");Element node = (Element)d.getElementsByTagName("book").item(0);Element newNode = d.createElement("publisher");newNode.setTextContent("lijizh");Element refChild = (Element)d.getElementsByTagName("color").item(0);node.insertBefore(newNode, refChild);TransformerFactory tff = TransformerFactory.newInstance();Transformer tf = tff.newTransformer();tf.transform(new DOMSource(d),new StreamResult("src/dtd/Book.xml"));}@Test//从XML文件中删除数据的方法publicvoid delete() throws ParserConfigurationException, SAXException, IOException,TransformerException{DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();DocumentBuilder db = factory.newDocumentBuilder();Document d = db.parse("src/dtd/Book.xml");Element node = (Element)d.getElementsByTagName("color").item(0);Element parent =(Element)node.getParentNode();parent.removeChild(node);TransformerFactory tff = TransformerFactory.newInstance();Transformer tf = tff.newTransformer();tf.transform(new DOMSource(d),new StreamResult("src/dtd/Book.xml"));}@Test从XML文件中更新数据的方法publicvoid update() throws ParserConfigurationException, SAXException, IOException,TransformerException{DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();DocumentBuilder db = factory.newDocumentBuilder();Document d = db.parse("src/dtd/Book.xml");Element node = (Element)d.getElementsByTagName("publisher").item(0);node.setTextContent("lijizh1013"); TransformerFactory tff = TransformerFactory.newInstance();Transformer tf = tff.newTransformer();tf.transform(new DOMSource(d),new StreamResult("src/dtd/Book.xml"));}}}


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/328887.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Aaron Stannard谈Akka.NET 1.1

Akka.NET 1.1近日发布&#xff0c;带来新特性和性能提升。InfoQ采访了Akka.net维护者Aaron Stannard&#xff0c;了解更多有关Akka.Streams和Akka.Cluster的信息。Aaron还阐述了与Akka for JVM实现有关的路线图计划。 InfoQ&#xff1a;这个版本有什么突出的特性&#xff1f; A…

以计算机网络为中介的人际传播,以计算机为中介的人际传播理论范式

20世纪90年代以来&#xff0c;以计算机为中介的传播(Computer-Mediated Communication&#xff0c;CMC)成为人类越来越普遍的经验。新技术深刻而全面地影响着人际传播的模式&#xff0c;并成为人际关系建立、发展和维系过程中不可或缺的因素。对实践过程的观察和研究形成了人际…

简单使用JDOM解析XML

转载自 简单使用JDOM解析XML使用JDOM解析XML一、前言 JDOM是Breet Mclaughlin和Jason Hunter两大Java高手的创作成果&#xff0c;2000年初&#xff0c;JDOM作为一个开放源代码项目正式开始研发。JDOM是一种解析XML的Java工具包。 DOM适合于当今流行的各种语言&#xf…

打造自己的LinqProvider

LinqProvider简介 本篇假设读者对Expression Tree 和Linq是有一定了解的&#xff0c;不了解的可以先看上面介绍Linq两篇文章,补一下课。 首先我们来看一下LinQProvide是如何执行的&#xff1a; 简单说明一下&#xff1a;我们写的Linq查询表达式将会被编译为方法调用链&#xff…

计算机硬件统的构成,计算机硬件统的构成部件.ppt

计算机硬件统的构成部件计算机硬件系统的构成部件 5.1 计算机硬件系统组成 5.2 中央处理器(CPU) 5.3 存 储 系 统 5.4 指令系统 计算机系统的基本构成 计算机硬件系统 指令和程序 计算机的工作过程 微型机主机的逻辑结构 微型计算机概述 计算机的总线 微型机主机的物理构成 BIO…

Java数据库连接池--DBCP浅析

转载自 Java数据库连接池--DBCP浅析前言对于数据库连接池, 想必大家都已经不再陌生, 这里仅仅设计Java中的两个常用数据库连接池: DBCP和C3P0(后续会更新). 一. 为何要使用数据库连接池假设网站一天有很大的访问量&#xff0c;数据库服务器就需要为每次连接创建一次数据库连接…

使用Visual Studio 2015 开发ASP.NET MVC 5 项目部署到Mono/Jexus

最新的Mono 4.4已经支持运行asp.net mvc5项目&#xff0c;有的同学听了这句话就兴高采烈的拿起Visual Studio 2015创建了一个mvc 5的项目&#xff0c;然后部署到Mono上&#xff0c;浏览下发现一堆错误出现&#xff0c;心中一万只草泥马奔腾而来&#xff0c;这也叫支持吗&#x…

体质测试数据统计软件,[体质测试数据excel自动统计表]体质测试数据Excel自动统计模板的研制...

《[体质测试数据excel自动统计表]体质测试数据Excel自动统计模板的研制》由会员分享&#xff0c;可在线阅读&#xff0c;更多相关《[体质测试数据excel自动统计表]体质测试数据Excel自动统计模板的研制(3页珍藏版)》请在装配图网上搜索。1、体质测试数据excel自动统计表体质测试…

常用数据库连接池 (DBCP、c3p0、Druid) 配置说明

转载自 常用数据库连接池 (DBCP、c3p0、Druid) 配置说明1. 引言 1.1 定义 数据库连接是一种关键的有限的昂贵的资源&#xff0c;这一点在多用户的网页应用程序中体现得尤为突出。对数据库连接的管理能显著影响到整个应用程序的伸缩性和健壮性&#xff0c;影响到程序的性能指标…

分布式基础通信协议:paxos,totem和gossip

背景&#xff1a; 在分布式中&#xff0c;最难解决的一个问题就是多个节点间数据同步问题。为了解决这样的问题&#xff0c;涌现出了各种奇思妙想。只有在解决了如何进行信息同步的基础之上才衍生出形形色色的应用。这里开始介绍几种分布式通信协议。 简单即有效——totem协议:…

计算机专业可以评机械工程师,机械工程师个人评价

人就像一个多面体。仅仅由别人的评价来判定自己是不全面的&#xff0c;当自己也沉淀下来&#xff0c;窥探自己的内心&#xff0c;写下自己的自我评价&#xff0c;这样才可以不断进步。但是自我评价要怎么写呢?下面是学习啦小编带来机械工程师个人评价范文的内容&#xff0c;欢…

分布式系统之消息队列

转载自 分布式系统之消息队列 一、MQ简介 消息队列中间件是分布式系统中重要的组件&#xff0c;主要解决应用耦合&#xff0c;异步消息&#xff0c;流量削锋等问题&#xff0c;实现高性能&#xff0c;高可用&#xff0c;可伸缩和最终一致性架构。 使用较多的消息队…

微软准备开源PowerShell

近日微软再次在向开源投出橄榄枝&#xff0c; PowerShell是面向Windows和Windows Server的自动化平台和脚本语言&#xff0c;帮助用户简化系统的管理。在纳德拉的带领下微软也逐渐走向开放&#xff0c;根据相关爆料称微软有计划在近期内 开源该脚本语言。 知名Windows爆料人士W…

华为荣耀畅玩7c计算机在那,华为荣耀畅玩7C内存多大

华为荣耀畅玩7C内存多大这是很多朋友咨询的问题&#xff0c;华为荣耀畅玩7C凭借高颜值&#xff0c;双摄&#xff0c;人脸识别受到广泛关注&#xff0c;但是也有很多朋友更关心内存多大的问题&#xff0c;下面就来详细介绍一下华为荣耀畅玩7C内存多大。华为荣耀畅玩7C内存多大?…

谈谈数据库连接池的原理

转载自 谈谈数据库连接池的原理这次我们采取技术演进的方式来谈谈数据库连接池的技术出现过程及其原理&#xff0c;以及当下最流行的开源数据库连接池jar包。 一.早期我们怎么进行数据库操作1.原理&#xff1a;一般来说&#xff0c;java应用程序访问数据库的过程是&#xff1a…

华为荣耀20计算机,华为云电脑将停止服务/荣耀新机保护壳曝光/小米新机渲染图曝光...

华为云电脑8月16日停止服务和运营近日&#xff0c;华为官方宣布&#xff0c;“华为云电脑”APP将于北京时间2021年8月15日23点59分停止服务和运营&#xff0c;自那之后用户将再无法登录和使用。华为表示“届时及以后您将无法登录和使用。在此之前&#xff0c;有效套餐仍可连接使…

.NET Core系列 :3 、使用多个项目

通过前面的两篇文章.NET Core系列 &#xff1a; 1、.NET Core 环境搭建和命令行CLI入门 和.NET Core系列 &#xff1a; 2 、project.json 这葫芦里卖的什么药&#xff0c;我们已经知道如何创建新的项目&#xff0c;如何生成并运行我们的应用程序&#xff0c;也知道&#xff08;…

Docker 入门教程

转载自 Docker 入门教程2013年发布至今&#xff0c; Docker 一直广受瞩目&#xff0c;被认为可能会改变软件行业。 但是&#xff0c;许多人并不清楚 Docker 到底是什么&#xff0c;要解决什么问题&#xff0c;好处又在哪里&#xff1f;本文就来详细解释&#xff0c;帮助大家理…

ftb测试软件,EXFO推出FTB-2光纤测试平台

ICCSZ讯 EXFO发布新的基于模块FTB-2 Pro紧凑型平台&#xff0c;这是目前市场上最小的高速、多技术和光学测试平台。它支持两个单插槽模块&#xff0c;如在同一单元中可进行以太网和光时域反射仪(OTDR)的组合测试功能。该系统还支持光谱和多层测试。总而言之&#xff0c;该平台提…

数据库设计【笔记】

数据库设计一、设计步骤1.收集信息&#xff08;来源项目需求分析&#xff09;2.标识实体&#xff08;一般是需求分析中需要管理的信息名词&#xff09;3.标识每个实体的属性4.实体之间的关系 二、画e-r图&#xff08;实体关系图&#xff09;1.矩形表示实体2.椭圆表示实体的属性…