我可以在XPath中为缺少的标签创建值吗?
时间:2020-03-05 18:46:40 来源:igfitidea点击:
我有一个使用XPath从XML文件提取数据的应用程序。如果该XML源文件中的节点丢失,我想返回值" N / A"(与Oracle NVL函数非常相似)。诀窍在于该应用程序不支持XSLT。我想单独使用XPath和XPath进行此操作。
那可能吗?
解决方案
回答
简短的回答:不。 XPath规范的版本2已考虑并明确拒绝了此类功能(请参阅非规范性说明性用户编写的功能部分)。
回答
可以使用XPath 1.0来完成。说你有
<foo> <bar/> </foo>
如果我们想测试foo是否有孩子baz,
substring("N/A", 4 * number(boolean(/foo/baz)))
如果表达式/ foo / baz
返回一个空节点集,将返回" N / A",否则返回一个空字符串。
回答
可以这样做,但前提是该节点确实存在时的返回值是该节点的字符串值,而不是该节点本身。 XPath
substring(concat("N/A", /foo/baz), 4 * number(boolean(/foo/baz)))
将返回baz
元素的字符串值(如果存在),否则返回字符串" N / A"。
概括该方法:
substring(concat($null-value, $node), (string-length($null-value) + 1) * number(boolean($node)))
其中$ null-value是空值字符串,$ node是选择节点的表达式。注意,如果$ node
评估为包含多个节点的节点集,则使用第一个节点的字符串值。
回答
@jelovirt
因此,如果我正确理解这一点,我们将默认答案和节点的值连接起来,然后通过测试节点的存在以将偏移量设置为零或者将其设置为零,从而获取结果字符串的正确子集。默认字符串。这是我见过的最扭曲的语言。 (我喜欢它!)
为了弄清我们所说的话,此方法在缺少节点时有效,而不是在节点为空时有效。但是通过将" number(boolean($ node))"替换为" string-length($ node)",它将代替空节点。
回答
对于空节点,我们需要
boolean(string-length($node))
(我们可以省略对number()的调用,因为从boolean到number的转换在这里是隐式的。)