Saya mencoba untuk meratakan objek bersarang seperti ini:
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; }
}
Izinkan saya memberi contoh. Ini adalah data yang saya miliki
Book: Pro Linq
{
Chapter 1: Hello Linq
{
Page 1,
Page 2,
Page 3
},
Chapter 2: C# Language enhancements
{
Page 4
},
}
Hasil yang saya cari adalah daftar datar berikut:
"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"
Bagaimana saya bisa mencapai ini? Saya dapat melakukannya dengan memilih baru tetapi saya telah diberitahu bahwa SelectMany sudah cukup.
.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)));
Dengan asumsi
books
adalah Daftar Buku:sumber
IEnumerable<Book>
akan dilakukan, tidak membutuhkan fileList<Book>
.sumber
Saya mencoba melakukan ini juga, dan dari komentar Yuriy dan mengotak-atik linqPad saya punya ini ..
Perhatikan bahwa saya tidak memiliki buku, bab, halaman, saya memiliki orang (buku), perusahaanPerson (bab) dan perusahaan (halaman)
atau
Situs referensi yang saya gunakan: http://odetocode.com/blogs/scott/archive/2008/03/25/inner-outer-lets-all-join-together-with-linq.aspx
sumber