6

请考虑以下 XML--

<div id="test">
    <p> Text sihdfaif</p>
    <p />
    <p> Text sihdfaif</p>
    <p />
    <p> Text sihdfaif</p>
    <p> Text sihdfaif</p>
    <p> Text sihdfaif</p>
</div>

现在,我想获取其中包含一些文本的 p 元素的数量。在这种情况下,该值 = 5(有 2 个“p”元素为空)

这是我想出的 XQuery——

    let $claims_main := $doc//div[@id="test"]
        let $claims := $doc//div[@id="test"]/p
        let $n := count($claims)
        where $claims_main/p != '' 
        return $n

然而我从上面得到的结果是7,即包括空的'p'元素。

我想到的另一种选择是对所有“p”元素使用for循环,但在这种情况下,我如何检索循环的元素总数?如果我在这种情况下使用 count ,那么我只会得到 [1,1,1,1,1]- 即。每个 p 元素的计数(因为在 for 循环中,计数将针对每个 'p' 元素,而不是 div 本身)...

4

2 回答 2

10

由于问题专门询问“p其中包含一些文本的元素”,因此这里是如何获得精确此类p元素的数量:

count(/*/div/p[string(.)])

这将生成p具有非空字符串值的所有元素的数量,这些元素div是 XML 文档顶部元素的子元素的子元素。

此外,如果“非空”也意味着具有非纯空格字符串值

count(/*/div/p[normalize-space(.)])
于 2012-09-16T16:13:17.650 回答
1

试试这个:

count($doc//div[@id='test']/p[node()])

第二个谓词[node()]只选择包含子节点的元素,它等价于[./node()].

于 2012-09-16T11:06:39.510 回答