XElement查询给出错误:"序列不包含任何元素"

Ste*_*ven 3 c# xml linq asp.net linq-to-xml

我正在尝试查询这个xml:

<pageMap>
  <pageMapNode id="8039CE09-E7DA-47E1-BCEC-DF96B5E411F4">
    <pageMapNode id="79DC0E8A-82F1-47DF-836E-099665A7D2E3"></pageMapNode>
    <pageMapNode id="3B79FAAC-EB2D-41AC-A91E-12541D0EB377">
      <pageMapNode id="170A9FC3-C03E-4088-AC5E-93AA038E0114"></pageMapNode>
    </pageMapNode>
  </pageMapNode>
  <pageMapNode id="A34CADA7-317D-405C-8E8F-DB113F40407F"></pageMapNode>
</pageMap>
Run Code Online (Sandbox Code Playgroud)

这是我的功能:

protected string GetParent(Guid nodeId)
{
    XDocument doc = XDocument.Parse(GetXml());  // parses xml displayed above

    // returns the 5 page map nodes displayed above
    IEnumerable<XElement> nodes = doc.Descendants("pageMapNode");

    // error: "Sequence contains no elements"
    XElement node = doc.Descendants("pageMapNode")
        .Where(n => n.Attribute("id").ToString().ToLower() == 
            nodeId.ToString().ToLower()).Single();

    ...
}
Run Code Online (Sandbox Code Playgroud)

我传入的nodeId参数是正确的 - 我应该得到一个匹配,所以我不知道它为什么会返回错误.

有谁看到我做错了什么?

Hen*_*man 5

n.Attribute("id")返回XAttribute,而不是字符串.你需要.Value而不是.ToString()

XElement node = doc.Descendants("pageMapNode")
    .Where(n => n.Attribute("id").Value.ToLower() == 
        nodeId.ToString().ToLower()).Single();
Run Code Online (Sandbox Code Playgroud)

你可以缩短它

XElement node = doc.Descendants("pageMapNode")
    .Single(n => n.Attribute("id").Value.ToLower() == 
        nodeId.ToString().ToLower());
Run Code Online (Sandbox Code Playgroud)