8

我有一个具有以下属性的类:

public class Author {
  public string FirstName { get; set; }
  public string LastName { get; set; }
}

接下来,我有一个作者列表,如下所示:

List<Author> authors = new List<Author> ();

authors.add(
  new Author { 
    FirstName = "Steven",
    LastName = "King"
  });

authors.add(
  new Author { 
    FirstName = "Homer",
    LastName = ""
  });

现在,我正在尝试使用 Linq to XML 来生成代表我的作者列表的 XML。

new XElement("Authors",
  new XElement("Author", 
    from na in this.Authors
    select new XElement("First", na.First)))

上面的块不会像我期望的那样生成 XML。我得到的是:

<Authors>
  <Author>
    <First>Steven</First>
    <First>Homer</First>
  </Author>
<Authors>

我希望 XML 输出看起来像:

<Authors>
  <Author>
    <First>Steven</First>
    <Last>King</Last>
  </Author>
  <Author>
    <First>Homer</First>
    <Last></Last>
  </Author>
</Authors>

任何关于如何让 XML 看起来像我需要的帮助将不胜感激!

4

2 回答 2

11

您需要将IEnumerable<XElement>查询作为第二个参数传递,而不是“作者”字符串,如下所示:

// Note the new way to initialize collections in C# 3.0.
List<Author> authors = new List<Author> ()
{
  new Author { FirstName = "Steven", LastName = "King" }),
  new Author { FirstName = "Homer", LastName = "" })
};

// The XML
XElement xml = new XElement("Authors",
    from na in this.Authors
    select new XElement("Author",
        new XElement("First", na.FirstName),
        new XElement("Last", na.LastName)));

这将为您提供所需的结果。

于 2009-07-14T19:12:08.680 回答
2

我知道您使用的是 C#,但这是您应该认真考虑将 VB.NET 项目添加到您的解决方案的时候。XML Literals 是完美的,并且使它更容易。

要从作者列表中获取 XML,您可以这样做:

Function GetAuthorsXML(authors As List(Of Author)) As XElement
    Return <Authors>
               <%= from a in authors _
                   select <Author>
                              <First><%= a.FirstName %></First>
                              <Last><%= a.LastName %></Last>
                          </Author> %>
           </Authors>
End Function
于 2009-07-14T19:22:37.143 回答