关键词: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掌握得越好,查询效率越好。
希望这篇小小的文章对你有所启发,如有错误,敬请批评指正。
闽公网安备 35060202000074号