Dom4j 操作, 节点查找 添加 删除 修改 。。。xPath
转:
Dom4j 操作, 节点查找 添加 删除 修改 。。。xPath
Dom4j 说明文档:http://blog.csdn.net/xj626852095/article/details/17000741
xPath说明文档: http://www.zvon.org/xxl/XPathTutorial/General_chi/examples.html
要解析的xml文件
- <?xml version="1.0" encoding="UTF-8"?>
- <书架>
- <书 name="yyyyyyy">
- <书名>Java</书名>
- <作者>张三</作者>
- <打折价>9.9折</打折价>
- <售价>只要998</售价>
- </书>
- <书 memony="有优惠价">
- <书名 name="xxxxx">JavaScript网页开发</书名>
- <作者>李四</作者>
- <售价>28.00元</售价>
- <优惠价>8折</优惠价>
- <优惠价>8折</优惠价>
- <优惠价>8折</优惠价>
- </书>
- <user username="kevin" passwd="123456"/>
- <user username="xiang" passwd="234567"/>
- </书架>
- package com.kevin.java;
- import static org.junit.Assert.*;
- import java.io.File;
- import java.io.FileOutputStream;
- import java.io.FileWriter;
- import java.io.IOException;
- import java.io.OutputStreamWriter;
- import java.util.List;
- import org.dom4j.Document;
- import org.dom4j.DocumentException;
- import org.dom4j.DocumentHelper;
- import org.dom4j.Element;
- import org.dom4j.Node;
- import org.dom4j.io.OutputFormat;
- import org.dom4j.io.SAXReader;
- import org.dom4j.io.XMLWriter;
- import org.junit.Test;
- import org.xml.sax.DocumentHandler;
- public class Dom4j_Test {
- //Xpath使用
- @Test
- public void test4() throws DocumentException, IOException {
- SAXReader reader = new SAXReader();
- Document document = reader.read(new File("src/book1.xml"));
- String bookName = document.selectSingleNode("//书名").getText();
- System.out.println("bookName: " + bookName);
- //查找符合条件的User //BBB[@id='b1'] 注意要有单引号
- String username = "kevin";
- String passwd = "123456";
- Node node = document.selectSingleNode
- ("//user[@username='"+username+"' and @passwd='"+passwd+"']");
- if(node==null)
- System.out.println("不是注册用户");
- else
- System.out.println("注册用户");
- }
- //获得第二本数的书名, 属性值 , 添加售价节点
- @Test
- public void test1() throws DocumentException, IOException {
- SAXReader reader = new SAXReader();
- Document document = reader.read(new File("src/book1.xml"));
- Element root = document.getRootElement();
- Element book = root.elements("书").get(1);
- String bookName = book.element("书名").getText();
- String bookAttr = book.element("书名").attributeValue("name");
- System.out.println("bookName: " + bookName);
- System.out.println("bookAttr: " + bookAttr);
- //添加售价节点
- book.addAttribute("memony", "有优惠价");
- book.addElement("优惠价").setText("8折");
- OutputFormat format = OutputFormat.createPrettyPrint();
- format.setEncoding("UTF-8");
- XMLWriter writer = new XMLWriter(
- new OutputStreamWriter(new FileOutputStream("src/book1.xml")), format);
- writer.write(document);
- writer.close();
- }
- //指定位置添加
- @Test
- public void test2() throws DocumentException, IOException {
- SAXReader reader = new SAXReader();
- Document document = reader.read(new File("src/book1.xml"));
- Element book = document.getRootElement().element("书");
- List list = book.elements();
- Element price = DocumentHelper.createElement("打折价");
- price.setText("9.9折");
- list.add(2, price);
- OutputFormat format = OutputFormat.createPrettyPrint();
- format.setEncoding("UTF-8");
- XMLWriter writer = new XMLWriter(
- new OutputStreamWriter(new FileOutputStream("src/book1.xml")), format);
- writer.write(document);
- writer.close();
- }
- //删除节点 更新节点
- @Test
- public void test3() throws DocumentException, IOException {
- SAXReader reader = new SAXReader();
- Document document = reader.read(new File("src/book1.xml"));
- Element priceTmp = document.getRootElement().element("书").element("打折价");
- //删除节点
- priceTmp.getParent().remove(priceTmp);
- Element price = document.getRootElement().element("书").element("售价");
- //更新节点
- price.setText("只要998");
- OutputFormat format = OutputFormat.createPrettyPrint();
- format.setEncoding("UTF-8");
- XMLWriter writer = new XMLWriter(
- new OutputStreamWriter(new FileOutputStream("src/book1.xml")), format);
- writer.write(document);
- writer.close();
- }
Dom4j 操作, 节点查找 添加 删除 修改 。。。xPath的更多相关文章
- dir(dict)|字典的创建-添加-删除-修改-判断存在-取值等相关操作
dir(dict) ####字典操作:创建-添加-删除-修改-判断存在-取值 #(一)创建字典: {} .等号. zip(). [(),()] #1.创建空字典 dict0 = {} #2.等号创建 ...
- JavaScript学习 - 基础(八) - DOM 节点 添加/删除/修改/属性值操作
html代码: <!--添加/删除/修改 --> <div id="a1"> <button id="a2" onclick=&q ...
- JTree 添加 , 删除, 修改
package com.swing.demo; import java.awt.BorderLayout; import java.awt.Container; import java.awt.eve ...
- SQL语句添加删除修改字段及一些表与字段的基本操作
用SQL语句添加删除修改字段 1.增加字段 alter table docdsp add dspcode char(200)2.删除字段 ALTER TABLE table_NA ...
- 用SQL语句添加删除修改字段、一些表与字段的基本操作、数据库备份等
用SQL语句添加删除修改字段 1.增加字段 alter table docdsp add dspcode char(200) 2.删除字段 ALTER TABLE table_NAME DROP CO ...
- SQL语句添加删除修改字段[sql server 2000/2005]
用SQL语句添加删除修改字段1.增加字段 alter table docdsp add dspcodechar(200)2.删除字段 ALTER TABLE table_NAME ...
- SQL语句添加删除修改字段
用SQL语句添加删除修改字段1.增加字段 alter table docdsp add dspcodechar(200)2.删除字段 ALTER TABLE table_NAME ...
- Entity framework 绑定到Datagridview的添加删除修改
Entity framework 绑定到Datagridview的添加删除修改 using System; using System.Collections.Generic; using System ...
- 节点操作-创建并添加&删除节点&替换&克隆节点
<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" ...
随机推荐
- AtCoder Grand Contest 026 D - Histogram Coloring
一列中有两个连续的元素,那么下一列只能选择选择正好相反的填色方案(因为连续的地方填色方案已经确定,其他地方也就确定了) 我们现将高度进行离散化到Has数组中,然后定义dp数组 dp[i][j] 表示前 ...
- CsvHelper文档-5配置
CsvHelper文档-5配置 CsvHelper库被设计成快速且简单易用,但是有时候默认的是设置不符合要求,需要你自己改变一些东西.所以csvHelper内置了很多自定义设置选项来改变读写行为.特别 ...
- python实现lower_bound和upper_bound
由于对于二分法一直都不是很熟悉,这里就用C++中的lower_bound和upper_bound练练手.这里用python实现 lower_bound和upper_bound本质上用的就是二分法,lo ...
- java 乐观锁 vs 悲观锁
在数据库的锁机制中介绍过,数据库管理系统(DBMS)中的并发控制的任务是确保在多个事务同时存取数据库中同一数据时不破坏事务的隔离性和统一性以及数据库的统一性. 悲观锁其实就是 完全同步 比如 sync ...
- Wormholes POJ 3259(SPFA判负环)
Description While exploring his many farms, Farmer John has discovered a number of amazing wormholes ...
- Beta周王者荣耀交流协会第六次会议
1.立会照片 成员王超,高远博,冉华,王磊,王玉玲,任思佳,袁玥全部到齐. master:袁玥 2. 时间跨度 2017年11月15日 19:00 — 19:10 ,总计10分钟. 3. 地点 一食堂 ...
- 20162320MyOD重做版
博客说明 由于上次的MyOD.java没有得分,所以这次我重做了这个java,代码是自己完成的,请教了一些同学的思路.故补交一篇博客来说明我对每一步代码的编写的想法以及理解. 代码片段及理解 1.先创 ...
- 《JavaScript》JS中的常用方法attr(),splice()
1.jquery中用attr()方法来获取和设置元素属性,attr是attribute(属性)的缩写,在jQuery DOM操作中会经常用到attr(),attr()有4个表达式. attr(属性名) ...
- mysql 查询数据库或某张表有多大(字节)
转载:https://www.cnblogs.com/diandiandidi/p/5582309.html 1.要查询表所占的容量,就是把表的数据和索引加起来就可以了 select sum(DATA ...
- VUE AXIOS 跨域问题
背景: 后台跨域使用通配符:context.Response.Headers.Add("Access-Control-Allow-Origin", "*"); ...