Я пытаюсь сгладить вложенные объекты следующим образом:
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; }
}
Приведу пример. Это данные, которые у меня есть
Book: Pro Linq
{
Chapter 1: Hello Linq
{
Page 1,
Page 2,
Page 3
},
Chapter 2: C# Language enhancements
{
Page 4
},
}
Результат, который я ищу, - это следующий плоский список:
"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"
Как я мог этого добиться? Я мог бы сделать это с помощью избранного нового, но мне сказали, что SelectMany будет достаточно.
.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)));
Предполагая,
books
что это список книг:источник
IEnumerable<Book>
подойдет любой , не нуженList<Book>
.источник
Я тоже пытался это сделать, и из комментариев Юрия и возни с linqPad у меня есть это ..
Обратите внимание, что у меня нет книг, глав, страниц, у меня есть человек (книги), компанияPerson (главы) и компании (страницы)
или
Ссылка на сайт, который я использовал: http://odetocode.com/blogs/scott/archive/2008/03/25/inner-outer-lets-all-join-to General-with-linq.aspx
источник