package com.njusc.xmlTest;
import java.io.File;
import java.util.Iterator;
import java.util.List;
import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;
public class TestDom4jReadExmple
{
/*
* 创建一个测试xml bicashy.xml
*
<?xml version="1.0" encoding="UTF-8"?>
<students>
<student age="25">
<name>云天河</name>
<college>野外学院</college>
<telephone>62354666</telephone>
<notes>一个从小在山野里长大的少年,双亲早亡,小小年纪就开始了自立的生活。</notes>
</student>
<student>
<name>韩菱纱</name>
<college leader="侠盗高飞">盗墓学院</college>
<telephone>62358888</telephone>
<notes>女,出身于盗墓世家,却对辨识墓穴位置、破解诡异机关、地脉风水之学颇有研究。</notes>
</student>
<student age="18">
<name>柳梦璃</name>
<college leader="">名门贵族</college>
<telephone>66666666</telephone>
<notes>梦璃是一个满怀柔情的女孩子,但她最温柔的一面只会留给自己喜欢的人。</notes>
</student>
<student age="18">
<name>慕容紫英</name>
<college>昆仑学院</college>
<telephone>88888888</telephone>
<notes>外冷内热、嫉恶如仇的热血青年,不但剑术超群,铸剑之术更是厉害。</notes>
</student>
</students>
*/
public static void main(String[] args) {
try{
//获取解析完后的解析信息
//利用XPath操作XML文件,获取想要的属性值
SAXReader saxReader = new SAXReader();
Document document = saxReader.read(new File("d:/bicashy.xml"));
/*直接定位到student name为云天河的节点的age属性*/
List list = document.selectNodes("/students/student[name=\"云天河\"]/@age");
Iterator iter = list.iterator();
if (iter.hasNext()) {
Attribute attribute = (Attribute) iter.next();
System.out.println("云天河-"+attribute.getName()+":"+attribute.getValue());
}
/*获取学生姓名为"韩菱纱"所在的学院名称*/
list = document.selectNodes("/students/student[name=\"韩菱纱\"]/college");
iter = list.iterator();
if (iter.hasNext()) {
Element element = (Element) iter.next();
String name = element.getName();
String value = element.getText();
System.out.println("韩菱纱-"+name+":"+value);
}
/*获取学生姓名为"韩菱纱"所在学院的师傅*/
list = document.selectNodes("/students/student[name=\"韩菱纱\"]/college/@leader");
iter = list.iterator();
if (iter.hasNext()) {
Attribute attribute = (Attribute) iter.next();
System.out.println("韩菱纱-college-"+attribute.getName()+":"+attribute.getValue());
}
/*获取学生姓名为"柳梦璃"的简介*/
list = document.selectNodes("/students/student[name=\"柳梦璃\"]/notes");
iter = list.iterator();
if (iter.hasNext()) {
Element element = (Element) iter.next();
System.out.println("柳梦-"+element.getName()+":"+element.getText());
}
/*获取年龄为"18"的学生的姓名、学院和电话号码*/
list = document.selectNodes("/students/student[@age='18']");
for(Object o:list){
Node n = (Node ) o;
Element name = (Element)n.selectObject("name");
Element college = (Element)n.selectObject("college");
Element telephone = (Element)n.selectObject("telephone");
System.out.println(name.getText()+"__ "+"college:"+college.getText()
+" telephone:"+telephone.getText());
}
/*获取年龄为"18",college的leader为空的学院名称*/
list = document.selectNodes("/students/student[@age='18']/college[@leader='']");
iter = list.iterator();
if (iter.hasNext()) {
Element element = (Element) iter.next();
System.out.println(""+element.getName()+":"+element.getText());
}
/*获取年龄为"18"姓名为"柳梦璃"、姓名、学院和电话号码*/
list = document.selectNodes("/students/student[@age='18'][name='柳梦璃']");
for(Object o:list){
Node n = (Node ) o;
Element name = (Element)n.selectObject("name");
Element college = (Element)n.selectObject("college");
Element telephone = (Element)n.selectObject("telephone");
System.out.println(name.getText()+"__ "+"college:"+college.getText()
+" telephone:"+telephone.getText());
}
/*获取年龄大于18的人的 姓名、学院和电话号码*/
list = document.selectNodes("/students/student[@age>18]");
for(Object o:list){
Node n = (Node ) o;
Element name = (Element)n.selectObject("name");
Element college = (Element)n.selectObject("college");
Element telephone = (Element)n.selectObject("telephone");
System.out.println(name.getText()+"__ "+"college:"+college.getText()
+" telephone:"+telephone.getText());
}
/*获取student所有的人的 姓名、学院和电话号码 */
//注 /students/student 可简写为//student根节点可以省去
list = document.selectNodes("//student");
for(Object o:list){
Node n = (Node ) o;
Element name = (Element)n.selectObject("name");
Element college = (Element)n.selectObject("college");
Element telephone = (Element)n.selectObject("telephone");
System.out.println(name.getText()+"__ "+"college:"+college.getText()
+" telephone:"+telephone.getText());
}
}catch(Exception ex){
ex.printStackTrace();
}
}
}
分享到:
相关推荐
dom4j和xpath的jar包,解析xml的最佳拍档.
NULL 博文链接:https://bbsanwei.iteye.com/blog/266394
XML节点访问的路径表达式【相对路径】和【绝对路径】的匹配原则
dom4j是一种解析XML文档的开放源代码XML框架。本文介绍如何使用包含在dom4j中的解析器创建并修改...与W3C DOM API相比,使用dom4j所包含的解析器的好处是dom4j拥有本地的XPath支持。DOM解析器不支持使用XPath选择节点。
dom4j 和dom4j 是一款比较好用的Xml解析工具jar,其中部分功能需要xpath的支持
xml+dom4j+xpath资料
该示例实现MAVEN来进行创建的,实现了dom4j操作XML文件,包括创建XML、动态创建XML节点、更新XML节点、删除XML节点。
dom4j基础入门文档,与 W3C DOM API 相比,使用 dom4j 所包含的解析器的好处是 dom4j 拥有本地的 XPath 支持。
详细介绍dom4j_xpath,相信对想学dom4j_xpath的朋友有帮助
这个例子我测试超过50多万条数据,用的是dom4j + Xpath 的解析,不错哦!不如你看看!
用dom4j解析xml时,经常需要用到xpath,由于dom4j-1.6.1.jar不包括jaxen-1.1-beta-6.jar,导致使用xpath报错。 其中jaxen-full.jar是为了解决ava.lang.NoClassDefFoundError: org/jaxen/JaxenException错误。 下载的...
使用dom4j解析xml时用到的jar包dom4j-1.6.1.zip xpath用到的jar包jaxen-1.1-beta-6.jar
Dom4j 解析XML 所使用的jar包,及添加XPath 支持所需要的 jar 包。具体使用可看我博客
很不错的东东哦,包括了dom4j-1.6.1.jar,用到XPath所需的jaxen-1.1.1.jar,以及你需要参考的dom4j的API文档、格式是chm的。
dom4j和xpath必备jar包对xml文档进行解析的必须jar包!
Dom,Sax,Xpath解析XML实例,有源码,实例。简单易用,直接可用
NULL 博文链接:https://wangweiwei358.iteye.com/blog/764548
资料来自javaweb学习所得