jaxp的dom方式操作(查找、添加、修改、删除、遍历节点)
package cn.itcast.jaxptest;
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.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;
public class TestJaxp {
public static void main(String[] args) throws Exception {
//selectAll();
//selectSin();
//addSex();
//modifySex();
//delSex();
listElement();
}
//查询所有name元素的值
private static void selectAll() throws ParserConfigurationException, SAXException, IOException {
//查询所有name元素的值
/*
*步骤:
*1、创建解析器工厂
*2、根据解析器工厂创建解析器
*3、解析xml返回document
*/
//创建解析器工厂
DocumentBuilderFactory builderFactory=DocumentBuilderFactory.newInstance();
//创建解析器
DocumentBuilder builder=builderFactory.newDocumentBuilder();
//解析xml返回的document
Document document=builder.parse("person.xml");
//得到name元素
NodeList list=document.getElementsByTagName("name");
//遍历集合
for(int i=0;i<list.getLength();i++){
Node name1=list.item(i);//得到里面name元素
String name=name1.getTextContent();//得到name元素的值
System.out.println(name);
}
}
//查询xml中第一个name元素的值
public static void selectSin() throws Exception{
/*
* 1、创建解析器工厂
* 2、根据解析器工厂创建解析器
* 3、解析xml,返回document
* 4、得到所有name元素
* 5、使用返回集合,里面方法item,下标获取具体的元素
* 6、得到具体的值,使用getTextContent方法
*
*/
//1、创建解析器工厂
DocumentBuilderFactory builderFactory=DocumentBuilderFactory.newInstance();
//2、根据解析器工厂创建解析器
DocumentBuilder builder=builderFactory.newDocumentBuilder();
//3、解析xml,返回document
Document document=builder.parse("person.xml");
//4、得到所有name元素
NodeList list=document.getElementsByTagName("name");
//5、使用集合里面的方法item,下标获取元素
Node node=list.item(0);
String name=node.getTextContent();
System.out.println(name);
}
//添加节点,在第一个p1下面添加一个sex女
public static void addSex() throws Exception{
/*
*1、创建解析器工厂
*2、创建解析器
*3、解析xml,返回document
*4、得到第一个p1
* -得到所有p1,使用item方法下标得到
*5、创建sex标签createElement
*6、创建文本createTextNode
*7、把文本添加到sex下面appendChild
*8、把sex添加到第一个p1下面
*9、回写xml,让写入文件生效
* --创建TransformerFactory对象:
* --创建Transformer对象
* --transform.
*
*
*/
//1、创建解析器工厂
DocumentBuilderFactory builderFactory=DocumentBuilderFactory.newInstance();
//2、创建解析器
DocumentBuilder builder=builderFactory.newDocumentBuilder();
//3、解析xml,返回document
Document document=builder.parse("person.xml");
//4、得到第一个p1
Node p1=document.getElementsByTagName("p1").item(0);
//5、创建sex标签createElement
Element sex1=document.createElement("sex");
//6、创建文本createTextNode
Text text1=document.createTextNode("nv");
//7、把文本添加到sex下面appendChild
sex1.appendChild(text1);
//8、把sex1添加到p1下面
p1.appendChild(sex1);
//9、回写
TransformerFactory factory=TransformerFactory.newInstance();
Transformer transformer=factory.newTransformer();
//transformer.transform(new DOMSource(document) , new StreamResult("person.xml"));
//操作文件需要用流,
transformer.transform(new DOMSource(document) , new StreamResult("person.xml"));
}
//使用jaxp修改节点
//修改第一个<sex>nan</sex>
public static void modifySex() throws Exception{
//1、创建解析器工厂
//2、创建解析器
//3、解析xml,得到document
//4、得到sex item方法
//5、修改sex里面的值setTextContent方法
//6、回写xml
//创建解析器工厂
DocumentBuilderFactory builderFactory=DocumentBuilderFactory.newInstance();
//2、创建解析器
DocumentBuilder documentBuilder=builderFactory.newDocumentBuilder();
//3、解析xml,得到document
Document document=documentBuilder.parse("person.xml");
//4、得到sex节点
Node sex1=document.getElementsByTagName("sex").item(0);
//5、设置sex的值
sex1.setTextContent("nan");
//6、回写
TransformerFactory factory=TransformerFactory.newInstance();
Transformer transformer=factory.newTransformer();
//把内存中的东西,写到文件中
transformer.transform(new DOMSource(document), new StreamResult("person.xml"));
}
//使用jaxp删除节点
//删除<sex></sex>
public static void delSex() throws Exception{
/**
* 1、创建解析器工厂
* 2、创建解析器
* 3、解析xml,得到document
* 4、获取sex元素
* 5、获取sex的父节点
* 6、使用父节点删除子节点removeChild
* 7、回写
*/
//1、创建解析器工厂
DocumentBuilderFactory builderFactory=DocumentBuilderFactory.newInstance();
//2、创建解析器
DocumentBuilder builder=builderFactory.newDocumentBuilder();
//3、解析xml,得到document
Document document=builder.parse("person.xml");
//4、获取sex元素
Node sex=document.getElementsByTagName("sex").item(0);
//5、获取sex父节点
Node parent=sex.getParentNode();
//6、使用父节点删除子节点
parent.removeChild(sex);
//7、回写
TransformerFactory factory=TransformerFactory.newInstance();
Transformer transformer=factory.newTransformer();
transformer.transform(new DOMSource(document), new StreamResult("person.xml"));
}
//使用jaxp遍历节点
public static void listElement() throws Exception{
/**
* 1、创建解析器工厂
* 2、创建解析器
* 3、解析xml,得到document
*
* 递归方法实现
* 4、得到根节点
* 5、得到根节点子节点
* 6、得到根节点子节点的子节点
*/
//1、创建解析器工厂
DocumentBuilderFactory builderFactory=DocumentBuilderFactory.newInstance();
//2、创建解析器
DocumentBuilder builder=builderFactory.newDocumentBuilder();
//3、解析xml文件,获得document
Document document= builder.parse("person.xml");
//递归实现得到根节点子节点
listNode(document);
}
//递归遍历,递归就是自己调自己
public static void listNode(Node node){
//判断是元素类型时候才打印
if(node.getNodeType()==Node.ELEMENT_NODE){
//打印元素名字
System.out.println(node.getNodeName());
}
}
}
jaxp的dom方式操作(查找、添加、修改、删除、遍历节点)的更多相关文章
- 用JAXP的dom方式解析XML文件
用JAXP的dom方式解析XML文件,实现增删改查操作 dom方式解析XML原理 XML文件 <?xml version="1.0" encoding="UTF-8 ...
- 打通前后端全栈开发node+vue进阶【课程学习系统项目实战详细讲解】(3):用户添加/修改/删除 vue表格组件 vue分页组件
第三章 建议学习时间8小时 总项目预计10章 学习方式:详细阅读,并手动实现相关代码(如果没有node和vue基础,请学习前面的vue和node基础博客[共10章] 演示地址:后台:demo ...
- SpringBoot定时任务升级篇(动态添加修改删除定时任务)
需求缘起:在发布了<Spring Boot定时任务升级篇>之后得到不少反馈,其中有一个反馈就是如何动态添加修改删除定时任务?那么我们一起看看具体怎么实现,先看下本节大纲: (1)思路说明: ...
- 【转】C#添加修改删除文件文件夹大全
[转]C#添加修改删除文件文件夹大全 C#添加修改删除文件文件夹大全 StreamWriter sw = File.AppendText(Server.MapPath(".")+& ...
- JavaWeb_day03_员工信息添加修改删除
day03员工的添加,修改,删除 修改功能 思路 : 点击修改员工数据之后,跳转到单行文本,查询要修改的员工id的全部信息,主键id设置为readonly,其余的都可以修改, 修改之后,提交按钮,提交 ...
- Web 1三级联动 下拉框 2添加修改删除 弹框
Web 三级联动 下拉框 using System; using System.Collections.Generic; using System.Linq; using System.Web; u ...
- div节点的操作(添加,删除,替换,克隆)
<html> <head> <title></title> <style type="text/css"> div{ b ...
- Xamarin.Android 入门实例(4)之实现对 SQLLite 进行添加/修改/删除/查询操作
1.Main.axml <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns: ...
- (一)DOM 常用操作 —— “查找”节点
在 DOM 树中,如果想要操作一个节点,那么首先要"查找"到这个节点.查找节点的方法由 Document 接口定义,而该接口由 JavaScript 中的 document 对象实 ...
随机推荐
- pytorch例子学习——TRAINING A CLASSIFIER
参考:https://pytorch.org/tutorials/beginner/blitz/cifar10_tutorial.html#sphx-glr-beginner-blitz-cifar1 ...
- 【CTF杂项】常见文件文件头文件尾格式总结及各类文件头
文件头文件尾总结 JPEG (jpg), 文件头:FFD8FF 文件尾:FF D9PNG (png), 文件头:89504E47 文件尾:AE 42 60 82GIF (gif), 文件头:47494 ...
- Java多线程(七)——线程休眠
一.sleep()介绍 sleep() 定义在Thread.java中.sleep() 的作用是让当前线程休眠,即当前线程会从“运行状态”进入到“休眠(阻塞)状态”.sleep()会指定休眠时间,线程 ...
- linux进程控制开发实例
fork.c #include <sys/types.h> #include <unistd.h> #include <stdio.h> #include < ...
- iOS开发简记(9):APPStore审核
"觅知音"这个APP的第一个版本从提交审核到上架,历时三个星期,其中遇到一些审核上的问题,它的处理或许能帮助到遇到同样问题的小伙伴们,所以这里列举出来,这三个星期如何跟苹果的审核团 ...
- 面试题-如何测试一个APP
问: 假如给你一个APP,你应该如何测试,分别从哪些方面来针对该APP进行测试. --- 1.安装.卸载测试 测试软件在不同操作系统(Android.iOS)下安装是否正常.软件安装后的是否能够正常运 ...
- python第六章:三大利器(装饰器,迭代器,生成器)--小白博客
python装饰器 什么是装饰器?在不修改源代码和调用方式的基础上给其增加新的功能,多个装饰器可以装饰在同一个函数上 # 原理(个人理解):将原函数(bar)的内存地址重新赋值,进行覆盖.新值为装饰器 ...
- H5 26-CSS三大特性之优先级
26-CSS三大特性之优先级 类>标签>通配符>继承>浏览器默认 --> 0 我是段落 <!DOCTYPE html> <html lang=" ...
- hdu 5584 LCM Walk
没用运用好式子...想想其实很简单,首先应该分析,由于每次加一个LCM是大于等于其中任何一个数的,那么我LCM加在哪个数上面,那个数就是会变成大的,这样想,我们就知道,每个(x,y)对应就一种情况. ...
- 一个6亿的表a,一个3亿的表b,通过外间tid关联,你如何最快的查询出满足条件的第50000到第50200中的这200条数据记录
1.如果A表TID是自增长,并且是连续的,B表的ID为索引 select * from a,b where a.tid = b.id and a.tid>500000 limit 200; 2. ...