之前的帖子中,提到了“XPath 轴(XPath Axes)”的概念,在使用 XPath 的过程中,采用灵活的相对路径可以很大程度上提高导航的性能和速度,而“XPath 轴”正是 XPath 相对路径的核心内容。
在上面的 XML 中,我们试图得到某个名称为 b 的节点的 id,我们假定此节点是位于 id 为 3 的 b 节点之后的第一个含有<sub></sub>子元素的节点。通过目测,可以看出,我们要找的节点正是 id 为 5 的 b 节点。那么如何得到这个 5 呢?
如果不使用相对路径,我们通常会采用从头遍历所有含有<sub></sub>子元素的 b 节点的方式,直到找到“位于 id 为 3 的 b 节点之后的第一个”。如果正是一个非常庞大的 XML,遍历全部肯定不是明智的选择。那么,我们不妨直接从 id 为 3 的 b 节点开始找吧! Roll Eyes
请看以下代码:
输出结果:
id: 5
其中,following:选取文档中当前节点的结束标签之后的所有节点。
类似的,preceding:选取文档中当前节点的开始标签之前的所有节点。
其他“XPath 轴”的内容,详见:[url]http://www.w3school.com.cn/xpath/xpath_axes.asp[/url]
<a>
<b id="1">aaa</b>
<b id="2">
<sub></sub>
</b>
<x>
<b id="3">ccc</b>
</x>
<b id="4">ddd</b>
<y>
<b id="5">
<sub></sub>
</b>
</y>
<b id="6">
<sub></sub>
</b>
</a>
在上面的 XML 中,我们试图得到某个名称为 b 的节点的 id,我们假定此节点是位于 id 为 3 的 b 节点之后的第一个含有<sub></sub>子元素的节点。通过目测,可以看出,我们要找的节点正是 id 为 5 的 b 节点。那么如何得到这个 5 呢?
如果不使用相对路径,我们通常会采用从头遍历所有含有<sub></sub>子元素的 b 节点的方式,直到找到“位于 id 为 3 的 b 节点之后的第一个”。如果正是一个非常庞大的 XML,遍历全部肯定不是明智的选择。那么,我们不妨直接从 id 为 3 的 b 节点开始找吧! Roll Eyes
请看以下代码:
……
VTDNav vn = vg.getNav();
AutoPilot ap = new AutoPilot(vn);
ap.selectXPath("//b[@id='3']"); // 先导航到 id 为 3 的 b 节点
if (ap.evalXPath() != -1) {
ap.resetXPath();
ap.selectXPath("following::b[sub]"); // 当前节点的结束标签之后的所有节点中,名称为b 并且含有<sub>子元素的节点
if (ap.evalXPath() != -1) {
int idIndex = vn.getAttrVal("id");
System.out.println("id: " + vn.toNormalizedString(idIndex)); //
}
}
……
输出结果:
id: 5
其中,following:选取文档中当前节点的结束标签之后的所有节点。
类似的,preceding:选取文档中当前节点的开始标签之前的所有节点。
其他“XPath 轴”的内容,详见:[url]http://www.w3school.com.cn/xpath/xpath_axes.asp[/url]