首页 > 学院 > 开发设计 > 正文

使用jdom的XPath来快速定位xml节点

2019-11-18 15:13:33
字体:
来源:转载
供稿:网友

  要害词:XPath,jdom

在用jdom来解析xml文档的时候,我们经常需要快速定位到某一个节点进行读取或修改操作。定位节点,这正是xpath表达式发挥作用的地方。从beta 9(www.jdom.org有下载)开始,jdom开始支持解析xpath路径表达式了,这样我们在用jdom来解析xml文档的时候,方便多了。请看例子

1.示例用xml文件,kk.xml

<?xml version = "1.0" encoding="GB2312" ?>
<联系人列表>
    <联系人>
        <姓名>张三</姓名>
        <ID>001</ID>
        <公司>A公司</公司>
        <EMAIL>zhang@aaa.com</EMAIL>
        <电话 类型="公司">(010)62345678</电话>
        <电话 类型="家庭">(010)88888888</电话>
        <地址>
            <街道>五街1234号</街道>
            <城市>北京市</城市>
            <省份>北京</省份>
        </地址>
    </联系人>

    <联系人>
        <姓名>李四</姓名>
        <ID>002</ID>
        <公司>B公司</公司>
        <EMAIL>li@bbb.org</EMAIL>
        <电话 类型="公司">(021)87654321</电话>
        <地址>
            <街道>南京路9876号</街道>
            <城市>上海</城市>
            <省份>上海</省份>
        </地址>
    </联系人>
</联系人列表>

2.为了找到张三的家庭的电话号码,使用下列代码段

package test;

import java.util.List;
import java.net.URL;
import org.jdom.*;
import org.jdom.xpath.*;
import org.jdom.input.*;
import java.io.*;
import java.util.*;

public class Test{
  public static void main(String[] args) throws Exception{

    SAXBuilder builder = new SAXBuilder();
    Document doc = builder.build("kk.xml");
    Element root = doc.getRootElement();

    XPath xpath = XPath.newInstance("//电话[../姓名='张三'][@类型='家庭']");
     List list = xpath.selectNodes(root);

     Iterator iter = list.iterator();
     while (iter.hasNext()) {
       Element item = (Element) iter.next();
       System.err.PRintln(item.getText());
     }

  }

输出结果正是我们想要的:(010)88888888.怎么样,很方便吧:)。

8过呢,我这个表达式效率不一定就是最高的,你对xpath把握得越好,查询效率越好。

希望这篇小小的文章对你有所启发,如有错误,敬请批评指正。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表