gpt4 book ai didi

XPath - 选择等于值的元素

转载 作者:行者123 更新时间:2023-12-03 04:54:14 25 4
gpt4 key购买 nike

在 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>

现在,使用 XPath:

//ccc[.='qwerty']

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

Name    Value
ccc qwerty

现在,使用 XPath:

//aaa[.='qwerty']

我得到意外结果:

Name    Value
aaa
aaa qwerty

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

X 路径:

//*[.='qwerty']

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

Name    Value
aaa
bbb
ddd qwerty
bbb qwerty
aaa qwerty
ccc qwerty

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

最佳答案

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

这解释了“奇怪的结果”。

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

//*[text() = 'qwerty']

上面选择了文档中至少有一个值为“qwerty”的文本节点子节点的每个元素。

//*[text() = 'qwerty' and not(text()[2])]

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

关于XPath - 选择等于值的元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3206975/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com