Jdom开发指南(XML读写操作及XPath语法分析)

JDOM是一个开源项目,它基于树型结构,利用纯JAVA的技术对XML文档实现解析、生成、序列化以及多种操作;使用JDOM可以方便的实现XML文档的读写操作。

下载地址:http://www.jdom.org/

开发包:jdom.jar,xerces.jar,jaxen-1.1-beta-4.jar

  XPath 是一门在 XML 文档中查找信息的语言。XPath 可用来在 XML 文档中对元素和属性进行遍历,XPath使用路径表达式来选择XML文档的节点或者节点集合。

 

Jdom基础知识:

Jdom常用数据类型介绍:Attribute(属性),CDATA,Coment(注释),DocType(文档类型),Document(文档),Element(元素),EntityRef,Namespace(命名空间), ProscessingInstruction(处理指令), Text(文本内容)

 

XPath语法分析:

(1)表达式说明:

nodename   Selects all child nodes of the node[选择所有目前节的子节]

/    Selects from the root node[从根节进行选择]

//   Selects nodes in the document from the current node that match the selection no matter where they are [选择文档中相吻合的节而不管其在文档的何处]

.    Selects the current node[选择当前节]

..    Selects the parent of the current node[当前节的父节]

@    Selects attributes[选择属性]

(2)通配符说明:

*     Matches any element node[相吻合的所有元素节]

@*   Matches any attribute node[相吻合的所有属性节]

node()  Matches any node of any kind[吻合任何类型的节]

(3)表达式常用函数说明:

string concat (string, string, string*)  联接两个字符串

boolean starts-with (string, string)  判断某字符串是否以另一字符串开头

boolean contains (string, string)  判断某字符串是否包含另一字符串

string substring (string, number, number)  取子字符串

number string-length (string)  测字符串长度

number sum (node-set)  求和

number floor (number)  求小于此数的最大整数值

number ceiling (number)  求大于此数最小整数值

(4)Xpath常用函数说明:

abstract  java.util.List selectNodes(java.lang.Object context)

          Evaluates the wrapped XPath expression and returns the list of selected items.

static java.util.List selectNodes(java.lang.Object context, java.lang.String path)

          Evaluates an XPath expression and returns the list of selected items.

abstract  java.lang.Object selectSingleNode(java.lang.Object context)

          Evaluates the wrapped XPath expression and returns the first entry in the

          list of selected nodes (or atomics).

static java.lang.Object selectSingleNode(java.lang.Object context, java.lang.String path)

          Evaluates the wrapped XPath expression and returns the first entry in the

          list of selected nodes (or atomics).

 

实例制作(xml文档操作):

1.firstpage.xml

<?xml version="1.0" encoding="GBK"?>

<data>

  <parent>

    <child id="1">child1</child>

    <child id="2">child2</child>

    <child id="3">

       <desc>

         <name>zhangsan</name>

         <sex>sex</sex>

         <age>10</age>

       </desc>

    </child>

  </parent>

</data>

2.JdomExample.java

import java.io.InputStreamReader;

import java.util.List;

import org.jdom.Document;

import org.jdom.Element;

import org.jdom.input.SAXBuilder;

import org.jdom.xpath.XPath;

 

public class JdomExample {

       public static void main(String args[]) {

              SAXBuilder builder = new SAXBuilder(

                            "org.apache.xerces.parsers.SAXParser", false);

              InputStreamReader config = null;

              // new JdomTest().getClass().getResourceAsStream("firstpage.xml");

              try {

                     config = new java.io.InputStreamReader(new java.io.FileInputStream(

                                   "firstpage.xml"), "GBK");

                     Document doc = builder.build(config);

                     Element root = doc.getRootElement();

                     echo(root);

                     // Xpath test

                     System.out.println("*********xpath test*****");

                     // org/jaxen/JaxenException

                     // lack:jaxen包

                     // parent下级节点;/表示根(绝对路径)

                     List list = XPath.selectNodes(root, "/data/parent/*");

                     System.out.println(list.size());// 3

                     // parent下所有节点 //选择文档中相吻合的节而不管其在文档的何处

                     list = XPath.selectNodes(root, "/data/parent//*");

                     System.out.println(list.size());// 7

                     list = XPath.selectNodes(root, "/child");

                     System.out.println(list.size());// 0

                     list = XPath.selectNodes(root, "//child");

                     System.out.println(list.size());// 3

                     list = XPath.selectNodes(root, "/data");

                     System.out.println(list.size());// 1

                     list = XPath.selectNodes(root, "//data");

                     System.out.println(list.size());// 1

                     list = XPath.selectNodes(root, "//parent");

                     System.out.println(list.size());// 1

                     list = XPath.selectNodes(root, "/parent");

                     System.out.println(list.size());// 0

                     list = XPath.selectNodes(root, "//child/desc/z");

                     System.out.println(list.size());// 0

                     list = XPath.selectNodes(root, "//child/desc/sex");

                     System.out.println(list.size());// 1

                     list = XPath.selectNodes(root, "//child/desc/sex");

                     System.out.println(list.size());// 1

                     //节点的附加元素,比如属性,函数等都要用方括号扩起来,属性前面要加上@号

                     // 属性验证(包含id属性的元素)

                     list = XPath.selectNodes(root, "//child[@id]");

                     System.out.println(list.size());// 3

                     // id=3

                     list = XPath.selectNodes(root, "//child[@id=3]");

                     System.out.println(list.size());// 1

                     // id>0

                     list = XPath.selectNodes(root, "//child[@id>0]");

                     System.out.println(list.size());// 3

                     // 前2个child元素

                     list = XPath.selectNodes(root, "//child[position()<3]");

                     System.out.println(list.size());// 2

                     // 倒数第二个child元素

                     list = XPath.selectNodes(root, "//child[last()-1]");

                     System.out.println(list.size());// 1

                     // 最后一个child元素desc子节点下所有元素

                     list = XPath.selectNodes(root, "//child[last()]/desc/*");

                     System.out.println(list.size());// 3

                     // 最后一个child元素所对应的所有下级子节点

                     list = XPath.selectNodes(root, "//child[last()]/*");

                     System.out.println(list.size());// 1

                     // 选择文档中所有name和sex元素

                     list = XPath.selectNodes(root, "//name|//sex");

                     System.out.println(list.size());// 2

                     Element currentElement = (Element) (XPath.selectSingleNode(root,

                                   "//child/desc"));

                     if (currentElement != null) {

                            System.out.println(currentElement.getName());// desc

                     }

                     // 父节点

                     list = XPath.selectNodes(currentElement.getParentElement(), "/*");

                     // 1:data

                     System.out.println(list.size() + ":"

                                   + ((Element) list.get(0)).getName());

                     // @@@@整个文档的所有节点,注意//不受元素的约束

                     list = XPath.selectNodes(currentElement.getParentElement(), "//*");

                     System.out.println(list.size());// 9

                     // 表示当前元素的下级元素,不包括第3级

                     list = XPath.selectNodes(currentElement.getParentElement(), "*");

                     // 1:desc

                     System.out.println(list.size() + ":"

                                   + ((Element) list.get(0)).getName());

                     // 可以接当前元素的下级元素,但不可以是孙以下元素

                     list = XPath.selectNodes(currentElement.getParentElement(), "sex");

                     System.out.println(list.size());// 0

                     list = XPath.selectNodes(currentElement.getParentElement(), "desc");

                     System.out.println(list.size());// 1

                     //Xpath函数处理

                     list = XPath.selectNodes(root, "//age[text()='10']");

                     //1:age找出文本为10的age元素

                     System.out.println(list.size() + ":"

                                   + ((Element) list.get(0)).getName());

              } catch (Exception e) {

                     // TODO Auto-generated catch block

                     e.printStackTrace();

              }

       }

 

       private static void echo(Element element) {

              // This returns a List of all the child elements nested directly (one

              // level deep)

              // within this element, as Element objects.

              List childrenList = element.getChildren();

              if (childrenList.size() <= 0) {

                     // 没有子元素

                     String eleValue = element.getText();

                     System.out.println("element value:" + eleValue);

              } else {

                     // 取得所有子元素的配置信息

                     for (int i = 0; i < childrenList.size(); i++) {

                            Element ele = (Element) childrenList.get(i);

                            echo(ele);

                     }

              }

 

       }

 

       private int getchildrenNum(List ls) {

              if (ls == null) {

                     return -1;

              }

              return ls.size();

       }

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
注:下文中的 *** 代表文件名中的组件名称。 # 包含: 中文-英文对照文档:【***-javadoc-API文档-中文(简体)-英语-对照版.zip】 jar包下载地址:【***.jar下载地址(官方地址+国内镜像地址).txt】 Maven依赖:【***.jar Maven依赖信息(可用于项目pom.xml).txt】 Gradle依赖:【***.jar Gradle依赖信息(可用于项目build.gradle).txt】 源代码下载地址:【***-sources.jar下载地址(官方地址+国内镜像地址).txt】 # 本文件关键字: 中文-英文对照文档,中英对照文档,java,jar包,Maven,第三方jar包,组件,开源组件,第三方组件,Gradle,中文API文档,手册,开发手册,使用手册,参考手册 # 使用方法: 解压 【***.jar中文文档.zip】,再解压其中的 【***-javadoc-API文档-中文(简体)版.zip】,双击 【index.html】 文件,即可用浏览器打开、进行查看。 # 特殊说明: ·本文档为人性化翻译,精心制作,请放心使用。 ·本文档为双语同时展示,一行原文、一行译文,可逐行对照,避免了原文/译文来回切换的麻烦; ·有原文可参照,不再担心翻译偏差误导; ·边学技术、边学英语。 ·只翻译了该翻译的内容,如:注释、说明、描述、用法讲解 等; ·不该翻译的内容保持原样,如:类名、方法名、包名、类型、关键字、代码 等。 # 温馨提示: (1)为了防止解压后路径太长导致浏览器无法打开,推荐在解压时选择“解压到当前文件夹”(放心,自带文件夹,文件不会散落一地); (2)有时,一套Java组件会有多个jar,所以在下载前,请仔细阅读本篇描述,以确保这就是你需要的文件;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值