使用LINQ对属性进行VB XML查询

时间:2009-02-27 16:51:38

标签: xml vb.net linq

我正在尝试学习LINQ并且有一个关于使用VB查询XML的问题。

我的XML:

 <Procedure-Text>
    <A ID="marker1"></A>Do This Procedure
 </Procedure-Text>
 <Procedure-Text>
    <A ID="marker2"></A>Do That Procedure
 </Procedure-Text>

如何指定查询以仅获取具有ID属性 marker2 的过程文本?换句话说,我想要一个结果字符串,表示执行该程序

由于

2 个答案:

答案 0 :(得分:6)

使用VB XML文字:

Dim marker2 = From x In data...<Procedure-Text> _
              Where x.<A>.@ID = "marker2" _
              Select x

三点式语法产生xml元素的“所有后代”,即data...<Procedure-Test>将在<Procedure-Test>

内生成data个标记的列表

XML文字上的点语法表示“第一个后代”,因此x.<A>将在x内产生<A>的第一个出现。其中x现在是<Procedure-Test>

的实例

现在你有了所需的<A>元素,将其id与字符串进行比较对于@attr属性选择器来说是微不足道的。如果<A>.@ID = "marker2"代码的ID属性等于“marker2”,True将评估为<A>

因此x.<A>.@ID表示“x”中第一个<A>标记的ID属性

您想要<Procedure-Text>元素,因此指定Select x

完整示例:

Sub Main()

    Dim data = <doc>
                   <Procedure-Text>
                       <A ID="marker1"></A>Do This Procedure
                   </Procedure-Text>
                   <Procedure-Text>
                       <A ID="marker2"></A>Do That Procedure
                   </Procedure-Text>
               </doc>

    Dim marker2 = From x In data...<Procedure-Text> _
                  Where x.<A>.@ID = "marker2" _
                  Select x

    ' prints the second procedure-text element
    Console.WriteLine(marker2.FirstOrDefault().ToString())

    Console.ReadKey()

End Sub

答案 1 :(得分:1)

linq查询

from x 
in d.Descendants("A") 
where x.Attribute("ID").Value == "marker2" 
select x.NextNode

换句话说,查找名为A的元素,其ID属性为“marker2”,并采用紧邻的下一个节点。

您可能希望对生成的枚举执行FirstOrDefault()以获取包含文本的XNode(实际上是XText)。