如何使用linq表达式展平嵌套对象

abx*_*x78 113 .net c# linq vb.net

我试图压扁这样的嵌套对象:

public class Book
{
    public string Name { get; set; }
    public IList<Chapter> Chapters { get; set; }
}

public class Chapter
{
    public string Name { get; set; }
    public IList<Page> Pages { get; set; }
}


public class Page
{
    public string Name { get; set; }
}
Run Code Online (Sandbox Code Playgroud)

让我举个例子.这是我的数据

Book: Pro Linq 
{ 
   Chapter 1: Hello Linq 
   {
      Page 1, 
      Page 2, 
      Page 3
   },
   Chapter 2: C# Language enhancements
   {
      Page 4
   },
}
Run Code Online (Sandbox Code Playgroud)

我要找的结果如下:

"Pro Linq", "Hello Linq", "Page 1"
"Pro Linq", "Hello Linq", "Page 2"
"Pro Linq", "Hello Linq", "Page 3"
"Pro Linq", "C# Language enhancements", "Page 4"
Run Code Online (Sandbox Code Playgroud)

我怎么能做到这一点?我可以选择新的,但我被告知SelectMany就足够了.

Yur*_*ich 184

myBooks.SelectMany(b => b.Chapters
    .SelectMany(c => c.Pages
        .Select(p => b.Name + ", " + c.Name + ", " + p.Name)));
Run Code Online (Sandbox Code Playgroud)

  • @ abx78:只需改变最后一个选择:`.Select(p => new FlatBook(b.Name,c.Name,p.Name))` (2认同)

boc*_*oca 48

假设books是一本书的清单:

var r = from b in books
    from c in b.Chapters
    from p in c.Pages
    select new {BookName = b.Name, ChapterName = c.Name, PageName = p.Name};
Run Code Online (Sandbox Code Playgroud)

  • +1,即使任何`IEnumerable&lt;Book&gt;` 都可以,不需要`List&lt;Book&gt;`。 (2认同)

Mad*_*ari 5

myBooks.SelectMany(b => b.Chapters
    .SelectMany(c => c.Pages
        .Select(p => new 
                {
                    BookName = b.Name ,
                    ChapterName = c.Name , 
                    PageName = p.Name
                });
Run Code Online (Sandbox Code Playgroud)

  • 虽然此代码示例可以回答这个问题,但它缺乏解释。就目前而言,它没有增加任何价值,并且代表被否决/删除的变化。请添加一些解释是什么以及为什么它是 OP 问题的解决方案。 (8认同)