dom4j+XPath
body, table{font-family: 微软雅黑; font-size: 10pt}
table{border-collapse: collapse; border: solid gray; border-width: 2px 0 2px 0;}
th{border: 1px solid gray; padding: 4px; background-color: #DDD;}
td{border: 1px solid gray; padding: 4px;}
tr:nth-child(2n){background-color: #f8f8f8;}
exam.xml | output.xml |
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<exam>
<student idcard="111" examid="222">
<name>张三</name>
<location>沈阳</location>
<grade>89</grade>
</student>
<student idcard="333" examid="444">
<name>李四</name>
<location>大连</location>
<grade>97</grade>
</student>
</exam>
|
<?xml version="1.0" encoding="utf-8"?>
<exam>
<student idcard="111" examid="222">
<name>张三</name>
<location>沈阳</location>
<grade>89</grade>
<sex>男</sex>
</student>
<student idcard="333" examid="444">
<name>李四</name>
<location>大连</location>
</student>
<student idcard="5555" examid="999"/>
</exam>
|
Dom4j.java | |
/* 针对exam.xml文件使用dom4j完成入下操作:
1,得到某个具体的节点内容
2、修改某个元素节点的主体内容
3、向指定元素节点中增加子元素节点
4、向指定元素节点上增加同级元素节点
5、删除指定元素节点
6、遍历所有元素节点
7、获取XML文件某元素属性
*/
|
//开头导入包省略
public class Dom4j {
public static void main(String[] args) throws Exception{
SAXReader reader=new SAXReader();
Document document=reader.read("exam.xml"); //获取document对象
//得到第一个人的姓名
Element rootElement = document.getRootElement();
Element firstStudent=rootElement.element("student");
Element firstName=firstStudent.element("name");
String firstNameText = firstName.getText();
System.out .println(firstNameText);
|
//修改第二个人的grade为100
List allStudentList = rootElement.elements();
Element secondStudent=(Element)allStudentList.get(1);
Element secGrade=secondStudent.element("grade");
secGrade.setText("100");
//第一个学生增加性别 - 男
Element firstStuSex= firstStudent.addElement("sex");
firstStuSex.setText("男");
//根节点增加同级元素 一个新的student
Element createnewElement = DocumentHelper.createElement("student");
createnewElement.setAttributeValue("idcard", "5555");
createnewElement.setAttributeValue("examid", "999");
rootElement.add(createnewElement);
//rootElement.addElement("student"); //第二种方式
//删除第二个学生的grade
secGrade.detach(); //remove()也行
|
//遍历所有元素
for(int i=0;i<allStudentList.size();++i){
Element tmpStu=(Element)allStudentList.get(i);
for(int j=0;j<tmpStu.elements().size();j++){
Element tmpChild=(Element)tmpStu.elements().get(j);
String str=tmpChild.getName();
String str1=tmpChild.getText();
System.out .println(str+" "+str1);
}
}
//获取XML属性
String xmlEncoding=document.getXMLEncoding();
String UniquePath=document.getUniquePath();
System.out .println(xmlEncoding+" "+UniquePath); //在当前目录
//标准的保存语句。
//dom4j写回文档会自动写换行方便观看
OutputFormat format = OutputFormat.createPrettyPrint(); // 指定XML编码
format.setEncoding("utf-8");
XMLWriter writer = new XMLWriter(new FileOutputStream ("output.xml"),format);
writer.write(document);
writer.close();
}
}
|
exam.xml | output2.xml |
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<exam>
<student idcard="111" examid="222">
<name>张三</name>
<location>沈阳</location>
<grade>89</grade>
</student>
<student idcard="333" examid="444">
<name>李四</name>
<location>大连</location>
<grade>97</grade>
</student>
</exam>
|
<?xml version="1.0" encoding="utf-8"?>
<exam>
<student idcard="111" examid="222">
<name>张三</name>
<location>沈阳</location>
<grade>100</grade>
</student>
<student idcard="333" examid="444">
<name>李四</name>
<location>大连</location>
</student>
</exam>
|
public class XPath {
public static void main(String[] args) throws Exception{
SAXReader reader = new SAXReader();
Document document = reader.read("exam.xml");
//得到第一个人的姓名
Node firstStuNameNode=document.selectSingleNode("/exam/student/name");
String firstStuName=firstStuNameNode.getText();
System.out.println(firstStuName);
//修改第二个人的grade为100
Node firstStuGradeNode = document.selectSingleNode("/exam/student/grade");
firstStuGradeNode.setText("100");
//删除第二个学生的grade
Node secStuNode=document.selectSingleNode("/exam/student[2]/grade");
secStuNode.detach();
//遍历所有元素
List allNodes=document.selectNodes("/exam/*");
for(int i=0;i<allNodes.size();++i){
Element subNodes=(Element)allNodes.get(i);
for(int j=0;j<subNodes.elements().size();++j){
String subName=((Element)subNodes.elements().get(j)).getName();
String subText=((Element)subNodes.elements().get(j)).getText();
System.out .println(subName+" "+subText);
}
}
|
//标准的保存语句。
OutputFormat format = OutputFormat.createPrettyPrint();
format.setEncoding("utf-8");
XMLWriter writer = new XMLWriter(new FileOutputStream ("output2.xml"),format);
writer.write(document);
writer.close();
}
}
//目前我还只会用XPath来定位,就比DOM4j简单的多,增加还不会
|
dom4j+XPath的更多相关文章
- dom4j 通过 org.dom4j.XPath 设置命名空间来支持 带namespace 的 xpath
测试文件 test.xml <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http:/ ...
- 如何使用DOM4j+xpath 解析
1.首先去dom4j官网下载一个对应版本的JAR包 XML的配置文件 导入一个config.xml文件 下面是dom4j+xpath解析XML文件
- Java解析XML汇总(DOM/SAX/JDOM/DOM4j/XPath)
[目录] 一.[基础知识——扫盲] 二.[DOM.SAX.JDOM.DOM4j简单使用介绍] 三.[性能测试] 四.[对比] 五.[小插曲XPath] 六.[补充] 关键字:Java解析xml.解析x ...
- JAVA与DOM解析器提高(DOM/SAX/JDOM/DOM4j/XPath) 学习笔记二
要求 必备知识 JAVA基础知识.XML基础知识. 开发环境 MyEclipse10 资料下载 源码下载 sax.dom是两种对xml文档进行解析的方法(没有具体实现,只是接口),所以只有它们是无 ...
- JAVA通过XPath解析XML性能比较(原创)
(转载请标明原文地址) 最近在做一个小项目,使用到XML文件解析技术,通过对该技术的了解和使用,总结了以下内容. 1 XML文件解析的4种方法 通常解析XML文件有四种经典的方法.基本的解析方式有两种 ...
- XML学习笔记(2)--dom4j操作XML
1. 介绍(四种方式的比较这部分转载自:http://www.blogjava.net/xcp/archive/2010/02/12/312617.html) 1)DOM(JAXP Crimson解析 ...
- Dom4j解析Xml文件,Dom4j创建Xml文件
Dom4j解析Xml文件,Dom4j创建Xml文件 >>>>>>>>>>>>>>>>>>&g ...
- java创建XML及开源DOM4J的使用
java import java.io.File; import java.io.StringWriter; import javax.xml.parsers.DocumentBuilder; imp ...
- XPath详解
xPath技术 1 引入 问题:当使用dom4j查询比较深的层次结构的节点(标签,属性,文本),比较麻烦!!! 2 xPath作用 主要是用于快速获取所需的节点对象. 3 在dom4j中如何使用 ...
随机推荐
- HDU 6162 Ch's gift(树链剖分+线段树)
题意: 已知树上的每个节点的值和节点之间的关系建成了一棵树,现在查询节点u到节点v的最短路径上的节点值在l到r之间的节点值的和. 思路: 用树链剖分将树映射到线段树上,线段树上维护3个值,max,mi ...
- BZOJ 1005: [HNOI2008]明明的烦恼(prufer数列)
http://www.lydsy.com/JudgeOnline/problem.php?id=1005 题意: Description 自从明明学了树的结构,就对奇怪的树产生了兴趣......给出标 ...
- mysql 存储过程简单实例
一.什么是存储过程 存储过程(Stored Procedure)是在大型数据库系统中,一组为了完成特定功能的SQL 语句集,存储在数据库中,经过第一次编译后再次调用不需要再次编译,用户通过指定存储过程 ...
- AttributeError: 'Request' object has no attribute 'json', cherrypy 无法接收到json字符串,解决方法
@cherrypy.expose @cherrypy.tools.accept(media="application/json") #加入这个装饰器 @cherrypy.too ...
- SpringMVC实现多种数据类型绑定
绑定基本数据类型 Java基本数据类型int的默认值是0,在使用int进行url传递参数时,参数key是必须写的,其值也只能是int类型的,否则将会报错. 比如方法: @RequestMapping( ...
- spring-cloud: eureka之:ribbon负载均衡自定义配置(二)
spring-cloud: eureka之:ribbon负载均衡自定义配置(二) 有默认配置的话基本上就是轮询接口,现在我们改用自定义配置,同时支持:轮询,随机接口读取 准备工作: 1.eureka服 ...
- linux下修改mysql登录密码
一.修改mysql密码 1.停止服务 /etc/init.d/mysqld stop 2.以不检查权限的方式启动 /etc/init.d/mysqld --skip-grant- ...
- 20170716xlVba销售明细转销售单据
Sub CreateSaleList() AppSettings On Error GoTo ErrHandler Dim StartTime As Variant '开始时间 Dim UsedTim ...
- 在 Confluence 6 中的 Jira 权限
只读(Read Only) 从你 JIRA 应用服务器上取得的用户,用户组和用户组成员.这些用户的信息只能通过你的 JIRA 服务器进行修改. https://www.cwiki.us/display ...
- USACO 铂金 T1
题意 给出一个数轴,每次可以选择停下并得到当前点的收益,或者继续随机向左右游走,走到边界游戏结束收益为0. 求从每个点出发的最大期望收益.(n<=1e5) 有一个显然的dp方程 这个方程是带环的 ...