zoukankan      html  css  js  c++  java
  • Java获取XML节点总结之读取XML文档节点

     个人博客地址:http://www.ijianmi.com/

    dom4j是Java的XML API,用来读写XML文件的。目前有很多场景中使用dom4j来读写xml的。
    要使用dom4j开发,需要下载导入dom4j相应的jar文件。
    官网下载:http://www.dom4j.org/dom4j-1.6.1/
    github下载:http://dom4j.github.io/
    下载解压之后如图所示:

    我们只需要把dom4j-1.6.1.jar文件构建到我们开发项目中就可以了。


    下面就以Eclipse创建java项目的构建方法为例说明:
    声明:本Java项目的开发环境JDK1.8,Eclipse版本 Neon.1 Release (4.6.1)
    首先创建一个demo项目:

    在demo项目中创建一个lib文件,把dom4j-1.6.1.jar文件拷贝到lib中,然后右键dom4j-1.6.1jar文件。如图所示:


    点击Add to Bulid Path即可构建到项目中去了。
    导入成功如图所示:

    在项目开发的过程中可以参考docs文件夹的(帮助文档),找到index.html打开,点击Quick start可以通过帮助文档进行学习 dom4j进行xml的解析。
    如图所示:


    下面我将以详细例子去介绍Java操作xml文件,文件名为exmple.java。

     1 package vastsum;
     2 
     3 import java.io.File;
     4 import java.util.Iterator;
     5 import java.util.List;
     6 
     7 import org.dom4j.Document;
     8 import org.dom4j.DocumentException;
     9 import org.dom4j.Element;
    10 import org.dom4j.Node;
    11 import org.dom4j.io.SAXReader;
    12 
    13 /**
    14  * 读取下xml文档,获得document对象。
    15  * 本文为xml连载第一篇,以下代码可以直接运行,结尾附上源码下载地址。
    16  */
    17 class exmple {
    18     public static void main(String[] args) throws DocumentException
    19     {
    20         SAXReader reader = new SAXReader();
    21         Document document = reader.read(new File("./src/contact.xml"));
    22         
    23         /**
    24          * 节点对象的操作方法
    25          */
    26         
    27         //获取文档根节点
    28         Element root = document.getRootElement();
    29         //输出根标签的名字
    30         System.out.println(root.getName());
    31         
    32         
    33         //获取根节点下面的所有子节点(不包过子节点的子节点)
    34         List<Element> list = root.elements() ;
    35         //遍历List的方法
    36         for (Element e:list){
    37             System.out.println(e.getName());
    38         }
    39         
    40         
    41         //获得指定节点下面的子节点
    42         Element contactElem = root.element("contact");//首先要知道自己要操作的节点。 
    43         List<Element> contactList = contactElem.elements();
    44         for (Element e:contactList){
    45             System.out.println(e.getName());
    46         }    
    47         
    48         
    49         //调用下面获取子节点的递归函数。
    50         getChildNodes(root);
    51         
    52         
    53         //获得当前标签下指定名称的第一个子标签
    54         Element conElem = root.element("contact");
    55         System.out.println(conElem.getName());
    56         
    57         
    58         //获得更深层次的标签(一层一层的获取)
    59         Element nameElem = root.element("contact").element("name");
    60         System.out.println(nameElem.getName());
    61     }
    62     
    63     //递归查询节点函数,输出节点名称
    64     private static void  getChildNodes(Element elem){
    65         System.out.println(elem.getName());
    66         Iterator<Node> it=    elem.nodeIterator();
    67         while (it.hasNext()){
    68             Node node = it.next();
    69             if (node instanceof Element){
    70                 Element e1 = (Element)node;
    71                 getChildNodes(e1);
    72                 }
    73             
    74             }
    75         }
    76     
    77     
    78 }

    下面是对应的xml文件,文件名为contact.xml:

     1 <?xml version="1.0" encoding="utf-8"?>
     2 <contactList>
     3     <contact id="001" class="style">
     4         <name>张三</name>
     5         <age>20</age>
     6         <phone>134222223333</phone>
     7         <email>zhangsan@qq.com</email>
     8         <qq>432221111</qq>
     9     </contact>
    10     <contact id="002">
    11         <name>李四</name>
    12         <age>20</age>
    13         <phone>134222225555</phone>
    14         <email>lisi@qq.com</email>
    15         <qq>432222222</qq>
    16     </contact>
    17     <contactTwo>
    18         <name>王五</name>
    19         <age>32</age>
    20         <phone>465431341</phone>
    21         <emali>af@qq.com</emali>
    22         <qq>46164694</qq>
    23     </contactTwo>
    24     <test>测试</test>
    25     <test>其他用途</test>
    26 </contactList>

    两个文件的目录如题所示:

  • 相关阅读:
    Jmeter之http性能测试实战 非GUI模式压测 NON-GUI模式 结果解析TPS——干货(十一)
    UI Recorder 自动化测试 回归原理(九)
    UI Recorder 自动化测试 录制原理(八)
    UI Recorder 自动化测试 整体架构(七)
    UI Recorder 自动化测试 配置项(六)
    UI Recorder 自动化测试 工具栏使用(五)
    UI Recorder 自动化测试 回归测试(四)
    UI Recorder 自动化测试 录制(三)
    UI Recorder 自动化测试工具安装问题疑难杂症解决(二)
    UI Recorder 自动化测试安装教程(一)
  • 原文地址:https://www.cnblogs.com/vastsum/p/5925033.html
Copyright © 2011-2022 走看看