使用LINQ搜索XML文档

时间:2010-01-16 11:14:02

标签: c# xml linq

我有一个与此类似的xml文档:

<Root>

    <MainItem ID="1">
        <SubItem></SubItem>
        <SubItem></SubItem>
        <SubItem></SubItem>
    </MainItem>
    <MainItem ID="2">
        <SubItem></SubItem>
        <SubItem></SubItem>
        <SubItem></SubItem>
    </MainItem>

    ...
</Root>

我想根据属性ID的值返回整个MainItem元素。 如果属性ID等于2,那么有效,然后再返回MainItem元素。

我无法解决如何使用LINQ执行此操作。 谷歌似乎有很多信息,但我似乎无法找到我正在寻找的东西。

很少帮忙?

TIA

: - )

4 个答案:

答案 0 :(得分:3)

可能是这样的:

        XDocument doc = XDocument.Load("myxmlfile.xml");
        XElement mainElement = doc.Element("Root")
                                    .Elements("MainItem")
                                    .First(e => (int)e.Attribute("ID") == 2);
        // additional work

答案 1 :(得分:2)

这个怎么样:

// load your XML
XDocument doc = XDocument.Load(@"D:\linq.xml");

// find element which has a ID=2 value
XElement mainItem = doc.Descendants("MainItem")
                          .Where(mi => mi.Attribute("ID").Value == "2")
                          .FirstOrDefault();

if(mainItem != null)
{ 
  // do whatever you need to do
}

马克

答案 2 :(得分:2)

我稍微更改了您的XML以获得值:

<?xml version="1.0"?>
<Root>
    <MainItem ID="1">
        <SubItem>value 1</SubItem>
        <SubItem>val 2</SubItem>
        <SubItem></SubItem>
    </MainItem>
    <MainItem ID="2">
        <SubItem></SubItem>
        <SubItem></SubItem>
        <SubItem></SubItem>
    </MainItem>
</Root>

有了这个LINQ:

XDocument xmlDoc = XDocument.Load(@"C:\test.xml");
var result = from mainitem in xmlDoc.Descendants("MainItem")
             where mainitem.Attribute("ID").Value == "1"
             select mainitem;


foreach (var subitem in result.First().Descendants())
{
    Console.WriteLine(subitem.Value);
}

Console.Read();

答案 3 :(得分:0)

从这里开始:How to: Filter on an Attribute (XPath-LINQ to XML)

// LINQ to XML query
IEnumerable<XElement> list1 =
    from el in items.Descendants("MainItem")
    where (string)el.Attribute("ID") == "2"
    select el;

// XPath expression
IEnumerable<XElement> list2 = items.XPathSelectElements(".//MainItem[@ID='2']");