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)
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)
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)
| 归档时间: |
|
| 查看次数: |
57115 次 |
| 最近记录: |