如何使用LINQ to XML检索更深层次的同级



我有一个XML结构,如下所示。我需要通过匹配命令属性来提取"Value"one_answers"String"吗?如何为此编写LINQ?

 <Root>
    <Command val="1001" type="sync">
      <Status>
        <DataList>
          <Info>
            <Value>1</Value>
            <String>Sample String 1 is set</String>
          </Info>
          <Info>
            <Value>2</Value>
            <String>Sample String 2 is set</String>
          </Info>
          <Info>
            <Value>3</Value>
            <String>Sample String 3 is set</String>
          </Info>
        </DataList>
      </Status>
    <Command>
</Root>

我尝试了以下操作,但在运行时出现异常。

lst = (
    from command in xmlDoc.Descendants("Command")
        .Descendants("Status")
        .Descendants("DataList")
    select new EnumList
    {
        val = command.Element("Value").Value,
        stringVal = command.Element("String").Value,
    })
    .ToList();

尝试

lst = (
    from command in xmlDoc.Descendants("Info")
    select new EnumList
    {
        val = command.Element("Value").Value,
        stringVal = command.Element("String").Value,
    })
    .ToList();

并且您在xml示例中有错误(没有关闭标记命令),请将其更改为

    </Command>
</Root>

相关内容

  • 没有找到相关文章

最新更新