dom技术解析xml下jaxp解析器详细代码
1.使用jaxp实现查询操作
person.xml
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<person>
<p1>
<name>宝娟</name>
<age>20</age>
<school>**大学**</school>
</p1>
<p1>
<name>鑫鑫</name>
<age>25</age>
<school>**大学**</school>
</p1>
</person>
package example4;
//jaxp技术解析xml文件
import java.io.IOException;
import java.util.function.DoubleConsumer;
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.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.w3c.dom.Text;
import org.xml.sax.SAXException;
//类名
class person {
//主方法
public static void main(String[] args) throws Exception {
// jaxp技术解析xml文件
// 1.创建解析器工厂
//selectAll();
//selectSome();
// addSex();
//modifySex();
//delSex();
visitAll();
}
// 向某一个标签下添加新的结点
private static void addSex() throws Exception {
DocumentBuilderFactory builderFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = builderFactory.newDocumentBuilder();
Document document = builder.parse("src/example4/person.xml");
// 获取标签
NodeList list = document.getElementsByTagName("school");
// 获得具体的一个节点
Node school1 = list.item(0);
// 创建一个新的节点
Element s = document.createElement("sex");
// 创建一个文本
Text text1 = document.createTextNode("男");
// 将新的节添加入某个节点之后
school1.appendChild(s);
// 在新节点之下添加文本
s.appendChild(text1);
// 经过以上操作之后,没有报错,但没有将具体内容写入xml文件,是因为这一切内容只是在内存中操作,接下来需要写入xml文件
// 回写xml文件(利用transformer类进行回写操作)
// 创建TransformerFactory解析工厂
TransformerFactory transformer = TransformerFactory.newInstance();
// 创建tansformer解析器
Transformer former = transformer.newTransformer();
former.transform(new DOMSource(document), new StreamResult("src/example4/person.xml"));
}
// 修改第一个节点<p1>下的sex改为女
private static void modifySex() throws Exception {
DocumentBuilderFactory builderFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = builderFactory.newDocumentBuilder();
Document document = builder.parse("src/example4/person.xml");
NodeList list = document.getElementsByTagName("sex");
Node name1 = list.item(0);
//重新设置sex的值
name1.setTextContent("女");
// xml回写
TransformerFactory transformer = TransformerFactory.newInstance();
Transformer former = transformer.newTransformer();
former.transform(new DOMSource(document), new StreamResult("src/example4/person.xml"));
}
// 删除节点sex
private static void delSex() throws Exception {
DocumentBuilderFactory builderFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = builderFactory.newDocumentBuilder();
Document document = builder.parse("src/example4/person.xml");
NodeList list = document.getElementsByTagName("sex");
//得到sex节点
Node name1 = list.item(0);
//得到sex的父节点
Node name2 = name1.getParentNode();
//父节点删除子节点
name2.removeChild(name1);
// xml回写
TransformerFactory transformer = TransformerFactory.newInstance();
Transformer former = transformer.newTransformer();
former.transform(new DOMSource(document), new StreamResult("src/example4/person.xml"));
}
// 只查询xml中某一结点的值
private static void selectSome() throws ParserConfigurationException, SAXException, IOException {
DocumentBuilderFactory builderFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = builderFactory.newDocumentBuilder();
Document document = builder.parse("src/example4/person.xml");
NodeList list = document.getElementsByTagName("name");
System.out.println(list.item(0).getTextContent());
}
// jaxp技术解析xml文件,获取所有的name
private static void selectAll() throws ParserConfigurationException, SAXException, IOException {
// 1.创建解析器工厂
DocumentBuilderFactory builderFactory = DocumentBuilderFactory.newInstance();
// 2.创建解析器
DocumentBuilder builder = builderFactory.newDocumentBuilder();
// 3.得到document对象
Document document = builder.parse("src/example4/person.xml");
// 4.获取想要的结果
NodeList list = document.getElementsByTagName("name");
//遍历结点列表
for (int i = 0; i < list.getLength(); i++) {
//得到结点
Node name = list.item(i);
//得到该节点的内容
String s = name.getTextContent();
System.out.println(s);
}
}
//遍历xml中的所有元素名称并打印输出
private static void visitAll() throws Exception {
DocumentBuilderFactory builderFactory=DocumentBuilderFactory.newInstance();
DocumentBuilder builder=builderFactory.newDocumentBuilder();
Document document=builder.parse("src/example4/person.xml");
list1(document);
}
//递归遍历的方法
private static void list1(Node node) {
//得到它的子节点序列
NodeList list=node.getChildNodes();
for(int i=0;i<list.getLength();i++) {
//的到每一个节点
Node node1=list.item(i);
//递归调用继续得到它的子节点序列
list1(node1);
}
//判断是元素类型才打印
if(node.getNodeType()==node.ELEMENT_NODE) {
System.out.println(node.getNodeName());
}
}
}
**以上是jaxp解析xml的提个简单方法介绍,不会的可以查找中文版手册,只需firefox或者google"java platform se 6"即可找到相关方法介绍,建议大家使用eclipse编辑器,每一步有提示,很方便。
如有其他问题,欢迎留言,我们一起讨论你一起学习。
**革命尚未成功,通知仍需努力!
转载于:https://www.cnblogs.com/aasu/p/9113025.html
dom技术解析xml下jaxp解析器详细代码相关推荐
- Java解析xml的主要解析器: SAX和DOM的选择(附上新方法--Pull解析)
Java的xml解析器库有很多,总的来说,万变不离其宗的就是SAX和DOM解析器. SAX的包是org.xml.sax DOM的包是org.w3c.dom 1) DOM DOM 是用与平台和语言无关的 ...
- java dom解析xml字符串_dom4j解析xml字符串实例
java部分 DOM4J 与利用DOM.SAX.JAXP机制来解析xml相比,DOM4J 表现更优秀,具有性能优异.功能强大和极端易用使用的特点,只要懂得DOM基本概念,就可以通过dom4j的api文 ...
- 解析XML文件——SAX解析技术
通常的文件等等都是以xml形式存储的,当我们要查看时就必须将他们解析出来.通常有nSimple API for XML(SAX) :nDocument Object Model(DOM)(不建议使用) ...
- java中解析xml解读,java解析xml(JDOM)
下面通过一个简单的例子说明一下怎么用JDOM这一适合Java程序员习惯的工具包来解析XML文档. 为了简单,我用了如下XML作为要解析的XML文件: rjzjh 60.0 够简单的吧,但它对于我们关心 ...
- python 解析xml格式_Python解析XML文件
1.概述 Python有三种方法解析XML:SAX,DOM,以及ElementTree: 1.SAX (simple API for XML ) python 标准库包含SAX解析器,SAX用事件驱动 ...
- java sax解析_Java 解析xml 之 SAX解析
SAX是什么 SAX是一种快速读写XML数据的方式. 局限 1.SAX分析器在解析xml文档时,触发了一系列事件,因为事件本身是有时序性的.因此SAX一旦经过了某个元素,没有办法返回再去访问. 2.S ...
- php解析xml数据格式,PHP解析xml格式数据工具类实例分享
本文主要介绍了PHP解析xml格式数据工具类,涉及php针对xml格式数据节点添加.获取.解析等相关操作技巧,需要的朋友可以参考下,希望能帮助到大家. 本文实例讲述了PHP解析xml格式数据工具类.分 ...
- c语言 自己编程解析 xml,C语言解析.XML文件
最近手头上有个活在忙,中间很重要的一部分就是用C语言将.XML文件中想要的key和value读出来,与之前已有的值进行比较. 核心的.XML文件的格式如下: zzz xxx yyy 而我的思路是这样的 ...
- java xsd 解析 xml文件_xsd解析xml
下面讲述根据xml生成对应序列化反序列化类的过程,xml需要首先转化为xsd,然后再生成为实体类.其中,XSD是XML Schema Definition的缩写. 1.拥有一个xml文件 2.打开vs ...
最新文章
- 【bzoj3309】DZY Loves Math 莫比乌斯反演+线性筛
- element ui 中el-input搜索输入框或者普通输入框无法输入的问题讨论
- 小程序云开发搜索功能的实现正则_几行代码实现小程序云开发提现功能
- [Android]用架构师角度看插件化(1)-Replugin入门剖析
- SAP UI5 应用开发教程之二十三 - 列表控件的排序 Sort 和分组 Group
- python idle 清屏问题的解决
- 【剑指offer - C++/Java】12、数值的整数次方
- 开关电源PCB排版基本要点概述
- AOP和IOC个人理解
- java测量麦克风音量_Android 获取麦克风的音量(分贝)
- Docker安装以及docker run hello-world 不能下载镜像报错
- 「ZigBee模块」基础实验(4)定时器T1的简单应用
- 苹果Apple TV+上线了重磅史诗级别科幻作品,这是要挑战Netflix、HBO?
- 解决kubernetes启动容器时,容器一直是ContainerCreating不能running
- 蓝桥杯——大臣的旅费
- 【汇正财经】沪深创集体红盘,两市近百股涨停
- Halcon找圆系列(4)测量圆直径/半径的方法之暴力拟合法 vs 测量工具法
- bzoj 4833: [Lydsy1704月赛]最小公倍佩尔数
- 狂补呼叫中心相关知识,将收集的资料贴于此
- GIS自主创新十年路(一):缘起ActiveMap