XPath - 选择等于值的元素

dev*_*per 95 xpath

在Xpath中,我想要选择等于特定值的元素.

示例XML数据:

<aaa id="11" >
    <aaa id="21" >
        <aaa id="31" ></aaa>
        <bbb id="32" >
            <aaa id="41" ></aaa>
            <bbb id="42" ></bbb>
            <ccc id="43" ></ccc>
            <ddd id="44" >qwerty</ddd>
            <ddd id="45" ></ddd>
            <ddd id="46" ></ddd>
        </bbb>
    </aaa>
    <bbb id="22" >
         <aaa id="33" >qwerty</aaa>
         <bbb id="34" ></bbb>
         <ccc id="35" ></ccc>
         <ddd id="36" ></ddd>
         <ddd id="37" ></ddd>
         <ddd id="38" ></ddd>
    </bbb>
    <ccc id="23" >qwerty</ccc>
    <ccc id="24" ></ccc>
 </aaa>
Run Code Online (Sandbox Code Playgroud)

现在,使用XPath:

//ccc[.='qwerty']
Run Code Online (Sandbox Code Playgroud)

我得到了正确的预期结果:

Name    Value
ccc     qwerty
Run Code Online (Sandbox Code Playgroud)

现在,使用XPath:

//aaa[.='qwerty']
Run Code Online (Sandbox Code Playgroud)

我得到了意外的结果:

Name    Value
aaa      
aaa     qwerty
Run Code Online (Sandbox Code Playgroud)

我特别感兴趣的是如何选择具有该值的任何元素

XPath的:

//*[.='qwerty']
Run Code Online (Sandbox Code Playgroud)

我得到了非常奇怪的意外结果:

Name    Value
aaa
bbb
ddd     qwerty
bbb     qwerty
aaa     qwerty
ccc     qwerty
Run Code Online (Sandbox Code Playgroud)

有人可以解释这些结果,以及如何修复我的XPath表达式以获得更多预期结果?

Dim*_*hev 158

XPath规范.将元素的字符串值定义为其所有文本节点后代的串联(按文档顺序).

这解释了"奇怪的结果".

使用以下表达式可以获得"更好"的结果:

//*[text() = 'qwerty']
Run Code Online (Sandbox Code Playgroud)

以上选择文档中具有至少一个值为'qwerty'的文本节点子元素的每个元素.

//*[text() = 'qwerty' and not(text()[2])]
Run Code Online (Sandbox Code Playgroud)

上面选择文档中只有一个文本节点子元素的每个元素,其值为:'qwerty'.

  • @iHeartGreek:很高兴它有效.接受/ upvoting怎么样?`text()`是XPath中可能的*node-tests*之一,意思是"这是一个文本节点吗?".其他节点测试是`comment()`,`processing-instruction()`,或者只是`node()`. (3认同)

Gre*_*ire 15

尝试

//*[text()='qwerty']因为.是你当前的元素