DOM对XML文档的增删改查
2013-11-26 23:02
323 查看
使用DOM对XML文档的增删改查
//获取得到当前XML文档
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
Document document = builder.parse("src/book.xml");
//增删改之后只是在内存上进行
//对文档进行增删改之后进行显示
TransformerFactory tffactory = TransformerFactory.newInstance();
Transformer tf = tffactory.newTransformer();
tf.transform(new DOMSource(document), new StreamResult(new FileOutputStream("src/book.xml")));
//查
//1.查找节点
Node node = document.getElementsByTagName_r("书架").item(0);//获取第一个书架
System.out.println(node.getNodeName());//通过getNodeName方法打印出节点
//2.查找节点内容
Node node = document.getElementsByTagName_r("书名").item(0);//获取第一个书名
String content = node.getTextContent(); //转换成字符串
System.out.println(content); //打印
//3.查找节点属性
Element name = (Element) document.getElementsByTagName_r("书名").item(0);//先转化为元素
String value = name.getAttribute("name");
System.out.println(value);
//增
//1.增加节点
//方法一:先创建一个节点,然后在该父节点中所有子节点后插入一个节点
Element price = document_create_rElement_x_x("售价");
price.setTextContent("98.00元");
Element jiedian = (Element) document.getElementsByTagName_r("书").item(0);
jiedian.a(price);
//方法二:找一个参考节点,然后再指定节点之前插入节点
//在内存中创建一个节点
Element price = document_create_rElement_x_x("售价");
price.setTextContent("28.00元");
//创建一个参考节点
Element refNode = (Element) document.getElementsByTagName_r("售价").item(0);
//得到上一个节点
Element book = (Element) document.getElementsByTagName_r("书").item(0);
//往book节点的指定位置插入
book.insertBefore(price, refNode);
//2.增加属性
//直接通过setAttribute方法添加
Element bookname = (Element) document.getElementsByTagName_r("作者").item(0);
bookname.setAttribute("name", "shuaige");
//删
//1.第一种删除节点方法
//先找到要删除的节点,然后再找出它的父节点,通过父节点删除子节点
//得到要删除的节点
Element e = (Element) document.getElementsByTagName_r("作者").item(1);
//得到父节点
Element book = (Element) document.getElementsByTagName_r("书").item(1);
//通过父节点删除要删除的节点
book.removeChild(e);
//第二种删除节点方法
//得到要删除的节点
Element e = (Element) document.getElementsByTagName_r("作者").item(1);
//得到父节点然后删除自己
e.getParentNode().removeChild(e);
//把它的父节点删除
//e.getParentNode().getParentNode().removeChild(e.getParentNode());
//2.删除属性
//得到要删除属性的节点
Element e = (Element) document.getElementsByTagName_r("作者").item(0);
e.removeAttribute("name");
//改
//改变节点中内容
Element e = (Element) document.getElementsByTagName_r("售价").item(0);
e.setTextContent("109.00元");
//获取得到当前XML文档
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
Document document = builder.parse("src/book.xml");
//增删改之后只是在内存上进行
//对文档进行增删改之后进行显示
TransformerFactory tffactory = TransformerFactory.newInstance();
Transformer tf = tffactory.newTransformer();
tf.transform(new DOMSource(document), new StreamResult(new FileOutputStream("src/book.xml")));
//查
//1.查找节点
Node node = document.getElementsByTagName_r("书架").item(0);//获取第一个书架
System.out.println(node.getNodeName());//通过getNodeName方法打印出节点
//2.查找节点内容
Node node = document.getElementsByTagName_r("书名").item(0);//获取第一个书名
String content = node.getTextContent(); //转换成字符串
System.out.println(content); //打印
//3.查找节点属性
Element name = (Element) document.getElementsByTagName_r("书名").item(0);//先转化为元素
String value = name.getAttribute("name");
System.out.println(value);
//增
//1.增加节点
//方法一:先创建一个节点,然后在该父节点中所有子节点后插入一个节点
Element price = document_create_rElement_x_x("售价");
price.setTextContent("98.00元");
Element jiedian = (Element) document.getElementsByTagName_r("书").item(0);
jiedian.a(price);
//方法二:找一个参考节点,然后再指定节点之前插入节点
//在内存中创建一个节点
Element price = document_create_rElement_x_x("售价");
price.setTextContent("28.00元");
//创建一个参考节点
Element refNode = (Element) document.getElementsByTagName_r("售价").item(0);
//得到上一个节点
Element book = (Element) document.getElementsByTagName_r("书").item(0);
//往book节点的指定位置插入
book.insertBefore(price, refNode);
//2.增加属性
//直接通过setAttribute方法添加
Element bookname = (Element) document.getElementsByTagName_r("作者").item(0);
bookname.setAttribute("name", "shuaige");
//删
//1.第一种删除节点方法
//先找到要删除的节点,然后再找出它的父节点,通过父节点删除子节点
//得到要删除的节点
Element e = (Element) document.getElementsByTagName_r("作者").item(1);
//得到父节点
Element book = (Element) document.getElementsByTagName_r("书").item(1);
//通过父节点删除要删除的节点
book.removeChild(e);
//第二种删除节点方法
//得到要删除的节点
Element e = (Element) document.getElementsByTagName_r("作者").item(1);
//得到父节点然后删除自己
e.getParentNode().removeChild(e);
//把它的父节点删除
//e.getParentNode().getParentNode().removeChild(e.getParentNode());
//2.删除属性
//得到要删除属性的节点
Element e = (Element) document.getElementsByTagName_r("作者").item(0);
e.removeAttribute("name");
//改
//改变节点中内容
Element e = (Element) document.getElementsByTagName_r("售价").item(0);
e.setTextContent("109.00元");
相关文章推荐
- hdu-2027-统计元音
- 数据字典生成Java代码
- PHP正则表达式函数
- POJ 1631 Bridging signals 解题报告(附详细分析)最长上升子序列的dp+二分
- 如何将flex 生成的可重入C词法扫描器与bison生成的C++语法解析器配接起来
- Python核心编程--学习笔记--4--Python对象
- smarty assign变量赋值
- 博客初记-从今天开始
- c语言循环线性队列的实现
- C运算符优先级
- Flex&Bison Tips - 如何改善 flex & bison 在VC下的编辑环境
- 巡检基本步骤
- 新词发现--暂记
- 【Hadoop】HDFS的运行原理
- 拓扑排序
- XML的基础理解
- c++中有关文件流读写的粗浅认识
- COCOS2DX学习笔记(一) windows下cocos2d-x的环境配置
- 词法分析生成器 之 Lexertl 【3】配合bison工作
- 4.错误代码:C8375BE4