Estoy tratando de aplanar objetos anidados como este:
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; }
}
Déjame hacer un ejemplo. Esta es la información que tengo
Book: Pro Linq
{
Chapter 1: Hello Linq
{
Page 1,
Page 2,
Page 3
},
Chapter 2: C# Language enhancements
{
Page 4
},
}
El resultado que estoy buscando es la siguiente lista plana:
"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"
¿Cómo podría lograr esto? Podría hacerlo con un nuevo select pero me han dicho que un SelectMany sería suficiente.
.Select(p => new FlatBook(b.Name, c.Name, p.Name))
myBooks.SelectMany(b => b.Chapters).SelectMany(c => c.Pages).Select(p => b.Name + ", " + c.Name + ", " + p.Name);
myBooks.SelectMany(b => b.Chapters == null || !b.Chapters.Any()? new []{b.Name + " has no Chapters"} : b.SelectMany(c => c.Pages.Select(p => b.Name + ", " + c.Name + ", " + p.Name)));
Suponiendo que
books
es una lista de libros:fuente
IEnumerable<Book>
lo hará, no necesita aList<Book>
.fuente
Estaba tratando de hacer esto también, y de los comentarios de Yuriy y jugando con linqPad tengo esto ...
Tenga en cuenta que no tengo libros, capítulos, páginas, tengo persona (libros), companyPerson (capítulos) y compañías (páginas)
o
Sitio de referencia que utilicé: http://odetocode.com/blogs/scott/archive/2008/03/25/inner-outer-lets-all-join-together-with-linq.aspx
fuente