dan*_*dan 5 ruby xpath nokogiri
您可以调用Nokogiri::XML::Node#ancestors.size以查看节点嵌套的深度。但是有没有办法确定节点的最深嵌套子节点的嵌套深度?
或者,如何找到从一个节点下降的所有叶节点?
您可以调用 Nokogiri::XML::Node#ancestors.size 来查看节点的嵌套深度。但是有没有办法确定节点嵌套最深的子节点的嵌套深度?
使用:
count(ancestor::node())
Run Code Online (Sandbox Code Playgroud)
该表达式表示上下文(当前)节点在文档层次结构中具有的祖先的数量。
要找到“最深嵌套子节点”的嵌套级别,必须首先确定所有“叶”节点:
descendant-or-self::node()[not(node())]
Run Code Online (Sandbox Code Playgroud)
并使用上面的 XPath 表达式获取它们中的每一个的嵌套级别。
然后必须计算最大嵌套级别(产生的所有数字的最大值),而最后的计算对于纯 XPath 1.0 是不可能的。
这可以用单个 XPath 2.0 表达式来表达:
max(for $leaf in /descendant-or-self::node()[not(node())],
$depth in count($leaf/ancestor::node())
return
$depth
)
Run Code Online (Sandbox Code Playgroud)
更新:
还可以进一步缩短此 XPath 2.0 表达式:
max(/descendant-or-self::node()[not(node())]/count(ancestor::node()))
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1771 次 |
| 最近记录: |