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入门到精通教程
查看: 382|回复: 0

[xml学习]使用dom4j和XPath解析XML之例子一

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

    [LV.1]初来乍到

    发表于 2014-10-10 01:01:25 | 显示全部楼层 |阅读模式
    包括三个文件:studentInfo.xml(待解析的xml文件), Dom4jReadExmple.java(解析的主要类), TestDom4jReadExmple.java(测试解析的结果) .

    TestDom4jReadExmple.java
    package dom4jExample.read; /**
      * 测试Dom4jReadExmple解析的情况
      * @author cuiweibing
      * @since 2007.8.10
      */
    public class TestDom4jReadExmple {
      public static void main(String[] args) {
          try{
            Dom4jReadExmple drb=new Dom4jReadExmple();
            //利用XPath操作XML文件,打印想要的属性值
            drb.printSelectedNodeValue("studentInfo.xml");
          }catch(Exception ex){
            ex.printStackTrace();
          }
        }
    }
      
       
       
         
       

         
       
      
      studentInfo.xml <?xml version="1.0" encoding="gb2312"?>
    <students>
         <student age="25"><!--如果没有age属性,默认的为20-->
             <name>崔卫兵</name>
             <college>PC学院</college>
             <telephone>62354666</telephone>
             <notes>男,1982年生,硕士,现就读于北京邮电大学</notes>
         </student>
         <student>
             <name>cwb</name>
             <college leader="leader1">PC学院</college><!--如果没有leader属性,默认的为leader-->
             <telephone>62358888</telephone>
             <notes>男,1987年生,硕士,现就读于中国农业大学</notes>
         </student>
         <student age="45">
             <name>xxxxx</name>
             <college leader="">xxx学院</college>
             <telephone>66666666</telephone>
             <notes>注视中,注释中</notes>
         </student>
         <student age="">
             <name>yyyyyy</name>
             <college leader="学院领导">yyyy学院</college>
             <telephone>88888888</telephone>
             <notes>注视中111,注释中222</notes>
         </student>
    </students> Dom4jReadExmple.java package dom4jExample.read; import java.io.File;
    import java.util.HashMap;
    import java.util.Iterator;
    import java.util.List; import org.dom4j.Attribute;
    import org.dom4j.Document;
    import org.dom4j.Element;
    import org.dom4j.io.SAXReader;
    /**
      * 利用dom4j与XPath进行XML编程
      * @author cuiweibing
      * @since 2007.8.10
      */
    public class Dom4jReadExmple {

      /**
       * 利用XPath操作XML文件,打印指定节点或者属性的值
       * @param filename String 待操作的XML文件(相对路径或者绝对路径)
       */
      public void printSelectedNodeValue(String filename){
       try {
        SAXReader saxReader = new SAXReader();
        Document document = saxReader.read(new File(filename));
        //打印所有student节点的属性age值,如果有的话
        List list = document.selectNodes("/students/student/@age");
        Iterator iter = list.iterator();
        while (iter.hasNext()) {
         Attribute attribute = (Attribute) iter.next();
         System.out.println("/students/student/@age:"+attribute.getValue());
        }
           //打印所有college节点值,如果有的话
        list = document.selectNodes("/students/student");
        iter = list.iterator();
        while (iter.hasNext()) {
          Element bookElement = (Element) iter.next();
          Iterator iterator = bookElement.elementIterator("college");
          while (iterator.hasNext()) {
           Element titleElement = (Element) iterator.next();
           System.out.println("/students/student/college:"+titleElement.getText());
          }
        }
        //测试节点的一些方法
        list = document.selectNodes("//telephone");
        iter = list.iterator();
        while (iter.hasNext()) {
          Element titleElement = (Element) iter.next();
          System.out.print("//telephone:getName:"+titleElement.getName());
          System.out.print("  ##getNodeType:"+titleElement.getNodeType());
          System.out.print("  ##getTextTrim:"+titleElement.getTextTrim());
          System.out.print("  ##getNamespaceURI:"+titleElement.getNamespaceURI());
          System.out.print("  ##getNodeTypeName:"+titleElement.getNodeTypeName());
          System.out.print("  ##getQualifiedName:"+titleElement.getQualifiedName());
          System.out.print("  ##getUniquePath:"+titleElement.getUniquePath());
          System.out.println("  ##getPath:"+titleElement.getPath());
        }
        //打印所有name节点值,如果有的话,与上面college的取法不一样
        list = document.selectNodes("/students/student/name");
        iter = list.iterator();
        while (iter.hasNext()) {
         Element titleElement = (Element) iter.next();
         System.out.println("/students/student/name:"+titleElement.getText());
       }
       } catch (Exception ex) {
        ex.printStackTrace();
       }
      }
    } 运行结果 /students/student/@age:25
    /students/student/@age:45
    /students/student/@age:
    /students/student/college:PC学院
    /students/student/college:PC学院
    /students/student/college:xxx学院
    /students/student/college:yyyy学院
    //telephone:getName:telephone  ##getNodeType:1  ##getTextTrim:62354666  ##getNamespaceURI:  ##getNodeTypeName:Element  ##getQualifiedName:telephone  ##getUniquePath:/students/student[1]/telephone  ##getPath:/students/student/telephone
    //telephone:getName:telephone  ##getNodeType:1  ##getTextTrim:62358888  ##getNamespaceURI:  ##getNodeTypeName:Element  ##getQualifiedName:telephone  ##getUniquePath:/students/student[2]/telephone  ##getPath:/students/student/telephone
    //telephone:getName:telephone  ##getNodeType:1  ##getTextTrim:66666666  ##getNamespaceURI:  ##getNodeTypeName:Element  ##getQualifiedName:telephone  ##getUniquePath:/students/student[3]/telephone  ##getPath:/students/student/telephone
    //telephone:getName:telephone  ##getNodeType:1  ##getTextTrim:88888888  ##getNamespaceURI:  ##getNodeTypeName:Element  ##getQualifiedName:telephone  ##getUniquePath:/students/student[4]/telephone  ##getPath:/students/student/telephone
    /students/student/name:崔卫兵
    /students/student/name:cwb
    /students/student/name:xxxxx
    /students/student/name:yyyyyy
      

      
      
       
       

         
       

         
       
      



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

    使用道具 举报

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

    本版积分规则

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

    GMT+8, 2024-6-19 01:48 , Processed in 0.392665 second(s), 46 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

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