gpt4 book ai didi

c# - 在 SelectSingleNode : Retrieving individual element from XML if it's present 中使用 XPath

转载 作者:可可西里 更新时间:2023-11-01 08:05:23 24 4
gpt4 key购买 nike

我的 XML 看起来像:

<?xml version=\"1.0\"?>
<itemSet>
<Item>one</Item>
<Item>two</Item>
<Item>three</Item>
.....maybe more Items here.
</itemSet>

一些单独的 Item 可能存在也可能不存在。假设我想检索元素 <Item> 两个 </Item> 如果它存在。我尝试了以下 XPath(在 C# 中)。

  • XMLNode node = myXMLdoc.SelectSingleNode("/itemSet[Item='two']") --- 如果 Item two 存在,则它只返回第一个元素 one。也许这个查询只是指向 itemSet 中的第一个元素,如果它在某个地方有一个值为 2 的 Item 作为子元素。这种解释正确吗?

所以我尝试了:

  • XMLNode node = myXMLdoc.SelectSingleNode("/itemSet[Item='two']/Item[1]") --- 我把这个查询读作,返回第一个 <Item> itemSet 中具有 value = 'two' 的元素。我说得对吗?

这仍然只返回第一个元素一个。我究竟做错了什么?在这两种情况下,我都可以使用兄弟节点遍历子节点并到达两个,但这不是我想要的。此外,如果没有两个,则 SelectSingleNode 返回 null。因此,我得到一个成功的返回节点这一事实确实表明元素二的存在,所以如果我想要一个 bool 测试来检查 two 的存在,上面的任何 XPath 就足够了,但我实际上需要完整的元素 <Item>two</Item> 作为我的返回节点。

[这是我的第一个问题,也是我第一次使用 Web 编程,所以我刚刚从过去的 SO 问题中即时学习了上述 XPath 和相关的 xml 内容。所以要温柔一点,如果我是个傻瓜或藐视任何社区规则,请告诉我。谢谢。]

最佳答案

我想你想要:

myXMLdoc.SelectSingleNode("/itemSet/Item[text()='two']")

换句话说,您想要的是包含两个文本的 Item,而不是包含它的 itemSet

您还可以使用一个点来指示上下文节点,在您的情况下:

myXMLdoc.SelectSingleNode("/itemSet/Item[.='two']")

编辑:.text() 之间的区别在于 . 有效地表示“此节点”,而 text( ) 表示“该节点的所有文本节点子节点”。在这两种情况下,比较都是针对 LHS 的“字符串值”。对于一个元素节点,字符串值是“该元素节点的所有文本节点后代的字符串值按文档顺序的串联”,对于文本节点集合,比较将检查是否有任何文本节点等于你正在测试的那个。

所以当元素内容只有一个文本节点时并不重要,但假设我们有:

<root>
<item name="first">x<foo/>y</item>
<item name="second">xy<foo/>ab</item>
</root>

然后 "root/item[.='xy']"的 XPath 表达式将匹配第一个项目,但是 "root/item[text()='xy'] "将匹配第二个。

关于c# - 在 SelectSingleNode : Retrieving individual element from XML if it's present 中使用 XPath,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/883698/

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