Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 328|回复: 0

[xml学习]JDOM处理XML快速上手--结合XPATH

[复制链接]
  • TA的每日心情
    开心
    2021-3-12 23:18
  • 签到天数: 2 天

    [LV.1]初来乍到

    发表于 2014-10-10 03:03:22 | 显示全部楼层 |阅读模式

       
                上次说到如果XML文件的层次比较多,直接通过 getChild() 方法获得元素将会是一件很痛苦的事情,用XPATH来处理就方便多了。JDOM从V1.0bata10版中,已经加入了对XPATH
         
       
         的支持。(拖了好久,今天总算是补上了。)
         
       
          
         
          XPATH基础
           XPATH遵循文档对象模型(DOM)的路径格式,基本语法由表达式构成。在计算表达式的值之后产生一个对象,这种对象有以下四种基本类型:节点集合、布尔型、数字型和字符串型。XPATH基本上和在文件系统中寻找文件类似,如果路径是以"/"开头的,就表明该路径表示的是一个绝对路径,这和在UNIX系统中关于文件路径的定义是一致的。以"//"开头
          
         
          则表示在文档中的任意位置查找。
          
         
       
      
       
      


      
       
      
       
            以样例XML文档(friends.xml)为例来了解XPATH:
       
      
              <?xml version="1.0" encoding="UTF-8"?>
       
            <friends comment="Friends List">
       
                <friend number="1">
       
                    <name>zoof</name>
       
                    <sex value="male" />
       
                    <phone>87654321</phone>
       
                 </friend>
       
                 <friend number="2">
       
                     <name>joe</name>
       
                     <sex value="male" />
       
                     <phone>87654322</phone>
       
                 </friend>
       
                 <friend number="3">
       
                     <name>joe</name>
       
                     <sex value="female" />
       
                     <phone>87654323</phone>
       
                 </friend>
       
             </friends>
       
      
       
       
      
              在XML文档中使用位置路径表达式来查找信息,这些表达式有很多种组成方式。一般我们用得最多的恐怕是 节点元素 查找。XPATH中用正斜杠(/)来分隔子结点,返回所有与
       
      
       模式相匹配的元素。下面以几个 表达式 的例子来说明一下返回结果:
       
      
             表达式:/friends/friend
       
           返回:根元素friends下所有的 friend 元素(或节点)。
       
      
       
       
      
             表达式:/friends/*
       
           返回:根元素friends下所有的元素(或节点)。(“*”相当于通配符,表示“所有”的)
       
      
       
       
      
             表达式://friend
       
           返回:任意元素(或节点)下的所有 friend 元素(或节点)。(注意:不仅仅是1中 根元素friends下面的friend元素,如果存在的话)
       
      
       
       
      
             表达式:/friends/friend[@number="1"]
       
           返回:根元素下元素名称为 friend,number属性为"1"的全部元素(或节点)。(对于元素或节点的附加元素,比如属性,函数等都要用方括号"[]"扩起来,属性前面要加
       
      
       上"@"号)
       
      
       
       
      
             表达式:/friends/friend/phone[text()="87654321"]
       
           返回:元素friends/friend下电话号码为 87654321 的全部元素。(text()是XPATH的函数,功能是取出当前节点的文本内容,即content。)
       
      
       
       
      
             表达式://name/parent::*
       
           返回:name元素的所有父元素(或节点)。(parent::* 表示这个元素的所有的父节点的集合)
       
      
       
       
      
             上面的介绍对于我们一般的应用基本上够用了,如果你需要进一步的深入,请查看W3C发布的关于XAPH的官方资料。
       
      
       
       
      
       JDOM+XPATH应用
       
      
       
       
      
             现在我们开始使用XPATH结合JDOM来操作XML文件了。JDOM的关于XPATH的api主要有一个类:Xpath.java,在org.jdom.xpath这个包中。这个类中的核心方法主要是两个静态方法:selectNodes()和selectSingleNode()。前者根据一个xpath语句返回一组节点:List;后者根据一个xpath语句返回符合条件的第一个节点:Object。
       
              public static List selectNodes(Object arg1,String arg2) throws org.jdom.JDOMException;
       
              public static Object selectSingleNode(Object arg1,String arg2) throws org.jdom.JDOMException;
       
          
       
      
             在使用XPATH之前,请先确定你的classpath路径里面有如下几个JAR包,如果没有,请从JDOM的发行包中lib目录下copy:
       
              saxpaht.jar
       
              jaxen-core.jar
       
              jaxen-jdom.jar
       
      
       
    样列JAVA代码:
       
      
       
    /*
       
      * Created on 2004-11-17
       
      *
       
      * TODO To change the template for this generated file go to
       
      * Window - Preferences - Java - Code Style - Code Templates
       
      */
       
       
      
       
       
      
       import java.io.IOException;
       
    import java.util.List;
       
      
       import org.jdom.Document;
       
    import org.jdom.Element;
       
    import org.jdom.Text;
       
    import org.jdom.JDOMException;
       
    import org.jdom.input.SAXBuilder;
       
    import org.jdom.xpath.XPath;
       
      
       /**
       
      * @author wanghua
       
      *
       
      * TODO To change the template for this generated type comment go to
       
      * Window - Preferences - Java - Code Style - Code Templates
       
      */
       
    public class XpathSample {
       
      public static void main(String[] args) throws JDOMException, IOException{
       
       SAXBuilder sb = new SAXBuilder();
       
       Document doc = sb.build("friends.xml");
       
       Element root = doc.getRootElement();
       
       
       
       List list = XPath.selectNodes(root,"/friends/friend");
       
       
       
       System.out.println("[info] Friends List:");
       
       for(int ii = 0; ii < list.size(); ii++){
       
        Element element = (Element)list.get(ii);
       
        String number = element.getAttributeValue("number");
       
       
       
       
       
        String name =
       
    ( (Text) XPath.selectSingleNode(element,"//friend[@number="" + number + ""]/name/text()")).getTextNormalize();
       
      
       
       
        String sex =
       
    ((Element)XPath.selectSingleNode(element,"//friend[@number="" + number + ""]/sex")).getAttributeValue("value");
       
       
       
       
       
        String phone =
       
    ( (Text) XPath.selectSingleNode(element,"//friend[@number="" + number + ""]/phone/text()")).getText();
       
       
       
        System.out.println("No."+number);
       
        System.out.println(" Name:[" + name + "]");
       
        System.out.println(" Sex:[" + sex + "]");
       
        System.out.println(" Phone:[" + phone + "]");
       
        System.out.println();
       
       }  
       
       System.out.println("[info] End of Friends List.");
       
      }
       
    }
       
      
       输出结果:
       
      
       [info] Friends List:
       
    No.1
       
      Name:[zoof]
       
      Sex:[male]
       
      Phone:[87654321]
       
      
       No.2
       
      Name:[joe]
       
      Sex:[male]
       
      Phone:[87654322]
       
      
       No.3
       
      Name:[joe]
       
      Sex:[female]
       
      Phone:[87654323]
       
      
       [info] End of Friends List.
       
      
       
       
      
       [参考资料]
       
             薛谷雨(
       rainight@126.com):JDOM/XPATH编程指南
       

       
      
    -


      
      
       
       

         
       

         
       
      
      
      

      










    源码下载:http://file.javaxxz.com/2014/10/10/030321765.zip
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-5-8 05:00 , Processed in 0.363825 second(s), 46 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

    快速回复 返回顶部 返回列表