在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'.
| 归档时间: |
|
| 查看次数: |
168608 次 |
| 最近记录: |