无法根据我的要求编写LINQ

时间:2014-04-06 06:09:33

标签: linq linq-to-xml

我有以下xml文件:

<?xml version="1.0" encoding="UTF-8"?>

<!-- New XML document created with EditiX XML Editor (http://www.editix.com) at Tue Mar 18 22:41:05 IST 2014 
-->
<html xsi:NamespaceSchemaLocation="http://www.w3.org/1999/xhtml DM_Project.xsd" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
    <head>
        <title>title1</title>
    </head>
    <body>
        <fragment name="heading" id="heading1">
            <h1>Heading 1</h1>
        </fragment>
        <fragment name="heading" id="heading2">
            <h2>Heading 2</h2>
        </fragment>
        <fragment name="paragraph" id="paragraph1">
            <p>Paragraph 1</p>
        </fragment>

    </body>
</html>

我编写了一个LINQ to xml查询,它提取片段标记之间的所有内容,如下所示:

XElement xelement = XElement.Load("C:\\Users\\Administrator\\Desktop\\DM_Project.xml");
var contents =
            from content in xelement.Elements("body").Elements("fragment").Descendants()
            select content;
            Console.WriteLine(contents);

正如预期的那样输出:

<h1>Heading 1</h1> 
<h2>Heading 2</h2> 
<p>Paragraph 1</p> 

但是,我正在尝试编写一个查询,它将返回片段标记与id =&#34; heading1&#34;之间的所有内容,如下所示:

XElement xelement = XElement.Load("C:\\Users\\Administrator\\Desktop\\DM_Project.xml");
var contents =
            from content in xelement.Elements("body").Elements("fragment").Descendants()
            where (string)xelement.Attributes("id") == "heading1"
            select content;
            Console.WriteLine(contents);

当我在LINQpad上运行此查询时,出现以下错误;

Cannot execute text selection: Cannot convert type 'System.Collections.Generic.IEnumerable<System.Xml.Linq.XAttribute>' to 'string'

任何人都可以指出我正在做的错误吗?

谢谢。

1 个答案:

答案 0 :(得分:0)

试试这个:

var contents =
    from content in xelement.Elements("body").Elements("fragment")
    where content.Attribute("id").Value == "heading1"
    select content;

您在xelement子句中重复content where的位置。